# MAGNACHIP SEMICONDUCTOR LTD. 8-BIT SINGLE-CHIP MICROCONTROLLERS WITH EMBEDDED FLASH

HMS99C51S HMS99C52S HMS99C54S HMS99C56S HMS99C58S

User's Manual (Ver. 1.01)



### **Revision History**

Ver 1.01 (Sep, 10, 2004) this book
The company name, Hynix Semiconductor Inc. changed to MagnaChip Semiconductor Ltd.

Ver 1.0 (Dec, 01, 2003) The first released document.

Version 1.01

Published by MCU Application Team

©2004 MagnaChip Semiconductor Ltd. All right reserved.

Additional information of this manual may be served by MagnaChip semiconductor offices in Korea or Distributors and Representatives listed at address directory.

MagnaChip semiconductor reserves the right to make changes to any information here in at any time without notice.

The information, diagrams and other data in this manual are correct and reliable; however, MagnaChip semiconductor is in no way responsible for any violations of patents or other rights of the third party generated by the use of this manual.

# **CONTENTS**

| DEVICE NAMING STRUCTURE                   | 1  |
|-------------------------------------------|----|
| HMS99C51S/52S/54S/56S/58S SELECTION GUIDE | 1  |
| FEATURE                                   | 2  |
| PIN CONFIGURATION                         | 4  |
| PIN DEFINITIONS AND FUNCTIONS             | 8  |
| FUNCTIONAL DESCRIPTION                    | 11 |
| CPU                                       | 12 |
| SPECIAL FUNCTION REGISTERS                | 13 |
| X2 MODE                                   | 19 |
| TIMER / COUNTER 0 AND 1                   | 21 |
| TIMER 2                                   | 22 |
| SERIAL INTERFACE (UART)                   | 23 |
| INTERRUPT SYSTEM                          | 24 |
| POWER SAVING MODES                        | 26 |
| ELECTRICAL CHARACTERISTICS                | 27 |
| OSCILLATOR CIRCUIT                        | 39 |
| FLASH MEMORY                              | 43 |
| IN-SYSTEM PROGRAMMING (ISP)               | 55 |
| ISP METHOD FOR PC (MAGNACHIP WINISP)      | 66 |





## **DEVICE NAMING STRUCTURE**



## HMS99C51S/52S/54S/56S/58S SELECTION GUIDE

| Operating   | ROM size (bytes)              | RAM size | Davies Name                                                   | Operating       |
|-------------|-------------------------------|----------|---------------------------------------------------------------|-----------------|
| Voltage (V) | FLASH                         | (bytes)  | Device Name                                                   | Frequency (MHz) |
| 4.5~5.5     | 4K<br>8K<br>16K<br>24K<br>32K | 256      | HMS99C51S<br>HMS99C52S<br>HMS99C54S<br>HMS99C56S<br>HMS99C58S | 40              |



### **FEATURE**

- Fully compatible to standard MCS-51 microcontroller
- Wide operating frequency up to 40MHz (for more detail, See "HMS99C51S/52S/54S/56S/58S SELECTION GUIDE" on page 1)
- X2 Speed Improvement capability (X2 Mode: 6 clocks/machine cycle)
   20MHz @5V (Equivalent to 40MHz @5V)
- ISP(In-System Programming) using Standard V<sub>CC</sub> Power Supply
- · Boot ROM Contains Low Level FLASH Programming Routines and a Default Serial Loader
- 4K/8K/16K/24K/32K bytes FLASH user program memory
  - Byte Write and Block(2K, 8K Bytes) Erase
- · 2K bytes FLASH boot loader
- 1 byte Hardware Security Byte (HSB)
- 256 bytes RAM
- · 64K bytes external program memory space
- · 64K bytes external data memory space
- · Four 8-bit ports
- Three 16-bit Timers / Counters (Timer2 with up/down counter feature)
- UART
- · One clock output port
- Programmable ALE pin enable / disable (Low EMI)
- Six interrupt sources, two priority levels
- Power saving Idle and power down mode
- P-DIP-40, P-LCC-44, P-MQFP-44 package
- Temperature Ranges : -40°C ~ 85°C

### Description

The Flash memory increases EPROM and ROM functionality with in-circuit electrical erasure and programming. It contains 4K, 8K, 16K, 24K or 32K bytes of program memory. This memory is both parallel and serial In-System Programmable(ISP). The ISP allows devices to alter their own program memory in the actual end product under software control through UART ports. A default serial loader(bootloader) program supports ISP of the Flash memory. The programming does not require external 12V programming voltage. The necessary high programming voltage is generated on-chip using the standard  $V_{\rm CC}$  pins of the microcontroller.



**Block Diagram** 





## PIN CONFIGURATION

## 44-PLCC Pin Configuration (top view)















**Logic Symbol** 





# PIN DEFINITIONS AND FUNCTIONS

|           | Pin Number   |             | er            | Input/ |                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |
|-----------|--------------|-------------|---------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Symbol    | PLCC-<br>44  | PDIP-<br>40 | MQFP-<br>44   | Output | Function                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |
| P1.0-P1.7 | 2-9          | 1-8         | 40-44,<br>1-3 | I/O    | Port1 Port 1 is an 8-bit bidirectional I/O port with internal pull-ups. Port 1 pins that have 1s written to them are pulled high by the internal pull-up resistors and can be used as inputs. As inputs, port 1 pins that are externally pulled low will source current because of the pulls-ups (I <sub>IL</sub> , in the DC characteristics). Port1 also serves alternate functions of Timer 2 as follows.                   |  |  |
|           | 2            | 1           | 40            |        | P1.0 / T2, Clock Out : Timer/counter 2 external count input, Clock Out P1.1 / T2EX :Timer/counter 2 trigger input                                                                                                                                                                                                                                                                                                              |  |  |
|           | 3            | 2           | 41            |        | Port1 receives the low-order address bytes during Flash programming and verifying.                                                                                                                                                                                                                                                                                                                                             |  |  |
| P3.0-P3.7 | 11,<br>13-19 | 10-17       | 5, 7-13       | I/O    | Port 3  Port 3 is an 8-bit bidirectional I/O port with interna pull-ups. Port 3 pins that have 1s written to them are pulled high by the internal pull-up resistors and can be used as inputs. As inputs, port 3 pins that are externally pulled low will source current because of the pulls-ups (I <sub>IL</sub> , in the DC characteristics). Port 3 also serves the special features of the 80C51 family, as listed below. |  |  |
|           | 11           | 10          | 5             |        | P3.0 / RxD receiver data input (asynchronous) or data input/output(synchronous) of serial interface 0                                                                                                                                                                                                                                                                                                                          |  |  |
|           | 13           | 11          | 7             |        | P3.1 / TxD transmitter data output (asynchronous) or clock output (synchronous) of the serial interface 0                                                                                                                                                                                                                                                                                                                      |  |  |
|           | 14           | 12          | 8             |        | P3.2 /INTO interrupt 0 input/timer 0 gate control                                                                                                                                                                                                                                                                                                                                                                              |  |  |
|           | 15           | 13          | 9             |        | P3.3 / INT1 interrupt 1 input/timer 1 gate control                                                                                                                                                                                                                                                                                                                                                                             |  |  |
|           | 16           | 14          | 10            |        | P3.4 /T0 counter 0 input                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |
|           | 17           | 15          | 11            |        | P3.5 /T1 counter 1 input                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |
|           | 18<br>19     | 16<br>17    | 12            |        | P3.6 / WR the write control signal latches the data byte from port 0 into the external data memory P3.7 /RD the read control signal enables the external data memory to port 0                                                                                                                                                                                                                                                 |  |  |
| XTAL2     | 20           | 18          | 14            | 0      | XTAL2 Output of the inverting oscillator amplifier.                                                                                                                                                                                                                                                                                                                                                                            |  |  |



|           | F           | Pin Numbe   | er          | Innut/           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |
|-----------|-------------|-------------|-------------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Symbol    | PLCC-<br>44 | PDIP-<br>40 | MQFP-<br>44 | Input/<br>Output | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |
| XTAL1     | 21          | 19          | 15          | ı                | Input to the inverting oscillator amplifier and input to the internal clock generator circuits. To drive the device from an external clock source, XTAL1 should be driven, while XTAL2 is left unconnected. There are no requirements on the duty cycle of the external clock signal, since the input to the internal clocking circuitry is divided down by a divide-by-two flip-flop. Minimum and maximum high and low times as well as rise and fall times specified in the AC characteristics must be observed.                                                                                                                                                                                                                                                                                   |  |  |  |
| P2.0-P2.7 | 24-31       | 21-28       | 18-25       | I/O              | Port 2 Port 2 is an 8-bit bidirectional I/O port with internal pull-ups. Port 2 pins that have 1s written to them are pulled high by the internal pull-up resistors and can be used as inputs. As inputs, port 2 pins that are externally pulled low will source current because of the pulls-ups (I <sub>IL</sub> , in the DC characteristics). Port 2 emits the high-order address byte during fetches from external program memory and during accesses to external data memory that use 16-bit addresses (MOVX @DPTR). In this application it uses strong internal pull-ups when outputting 1s. During accesses to external data memory that use 8-bit addresses (MOVX @Ri), port 2 emits the contents of the P2 special function register.  Some Port 2 pins receive the high-order address bits |  |  |  |
| PSEN      | 32          | 29          | 26          | 0                | during flash program, verify, and erase operations.  The Program Store Enable  The read strobe to external program memory wher the device is executing code from the external program memory. PSEN is activated twice each machine cycle, except that two PSEN activations are skipped during each access to external data memory. PSEN is not activated during fetches from internal program memory.                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |
| RESET     | 10          | 9           | 4           | I                | RESET A high level on this pin for two machine cycles while the oscillator is running resets the device. The port pins will be driven to their reset condition when a minimum V <sub>IH</sub> voltage is applied whether the oscillator is running or not. An internal diffused resistor to V <sub>SS</sub> permits power-on reset using only an external capacitor to V <sub>CC</sub> .                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |



|                      | F             | Pin Numbe   | er            | Immust/          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |
|----------------------|---------------|-------------|---------------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Symbol               | PLCC-<br>44   | PDIP-<br>40 | MQFP-<br>44   | Input/<br>Output | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |
| ALE /<br>PROG        | 33            | 30          | 27            | 0                | The Address Latch Enable / Program pulse  Output pulse for latching the low byte of the address during an access to external memory. In norma operation, ALE is emitted at a constant rate of 1/6 the oscillator frequency, and can be used for external timing or clocking. Note that one ALE pulse is skipped during each access to external data memory. This pir is also the program pulse input (PROG) during EPROM programming.  If desired, ALE operation can be disabled by setting bit 0 of SFR location 8E <sub>H</sub> . With this bit set, the pin is weakly pulled high. The ALE disable feature will be terminated by reset. Setting the ALE-disable bit has no affect if the microcontroller is in external executior mode. |  |  |  |
| EA / V <sub>PP</sub> | 35            | 31          | 29            | I                | External Access Enable / Program Supply Voltage<br>EA must be externally held low to enable the device to fetch code from external program memory locations<br>0000 <sub>H</sub> to FFFF <sub>H</sub> . If EA is held high, the device executes from internal program memory unless the program counter contains an address greater than its internal memory size. This pin also receives the 12.75V programming supply voltage (V <sub>PP</sub> ) during EPROM programming.  Note; however, that if any of the Lock bits are                                                                                                                                                                                                              |  |  |  |
|                      |               |             |               |                  | programmed, EA will be internally latched on reset.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |
| P0.0-P0.7            | 36-43         | 32-39       | 30-37         | I/O              | Port 0 Port 0 is an 8-bit open-drain bidirectional I/O port. Port 0 pins that have 1s written to them float and can be used as high-impedance inputs. Port 0 is also the multiplexed low-order address and data bus during accesses to external program and data memory. In this application it uses strong internal pull-ups when emitting 1s. Port 0 also receives and outputs the code bytes during program and verification respectively in the GMS99X5X. External pull-up resistors are required during program verification.                                                                                                                                                                                                         |  |  |  |
| V <sub>SS</sub>      | 22            | 20          | 16            | -                | Circuit ground potential                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |
| V <sub>C</sub> C     | 44            | 40          | 38            | -                | Supply terminal for all operating modes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |
| N.C.                 | 1,12<br>23,34 | -           | 6,17<br>28,39 | -                | No connection                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |



## **FUNCTIONAL DESCRIPTION**

The HMS99C51S/52S/54S/56S/58S are fully compatible to the standard 8051 microcontroller family.

It is compatible with the general 8051 family, while maintaining all architectural and operational characteristics of the general 8051 family.

Figure 1 shows a block diagram of the HMS99C51S/52S/54S/56S/58S.



Figure 1. Block Diagram of the HMS99C51S/52S/54S/56S/58S



## **CPU**

The HMS99C51S/52S/54S/56S/58S are efficient both as a controller and as an arithmetic processor. It has extensive facilities for binary and BCD arithmetic and excels in its bit-handling capabilities. Efficient use of program memory results from an instruction set consisting of 44% one-byte, 41% two-byte, and 15% three-byte instructions. With a 12 MHz crystal, 58% of the instructions are executed in  $1.0\mu s$  (40MHz: 300ns).

### **Special Function Register PSW**



| В                       | it                             | Function                                                                                                                                                                                                                                                                                           |
|-------------------------|--------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| С                       | Υ                              | Carry Flag                                                                                                                                                                                                                                                                                         |
| Α                       | С                              | Auxiliary Carry Flag (for BCD operations)                                                                                                                                                                                                                                                          |
| F                       | 0                              | General Purpose Flag                                                                                                                                                                                                                                                                               |
| RS1<br>0<br>0<br>1<br>1 | <b>RS0</b><br>0<br>1<br>0<br>1 | Register Bank select control bits  Bank 0 selected, data address 00 <sub>H</sub> - 07 <sub>H</sub> Bank 1 selected, data address 08 <sub>H</sub> - 0F <sub>H</sub> Bank 2 selected, data address 10 <sub>H</sub> - 17 <sub>H</sub> Bank 3 selected, data address 18 <sub>H</sub> - 1F <sub>H</sub> |
| 0                       | V                              | Overflow Flag                                                                                                                                                                                                                                                                                      |
| F                       | 1                              | General Purpose Flag                                                                                                                                                                                                                                                                               |
| F                       |                                | Parity Flag Set/cleared by hardware each instruction cycle to indicate an odd/even number of "one" bits in the accumulator, i.e. even parity.                                                                                                                                                      |

Reset value of PSW is 00<sub>H</sub>.



## **SPECIAL FUNCTION REGISTERS**

All registers, except the program counter and the four general purpose register banks, reside in the special function register area.

The 28 special function registers (SFR) include pointers and registers that provide an interface between the CPU and the other on-chip peripherals. There are also 128 directly addressable bits within the SFR area.

All SFRs are listed in Table 1, Table 2, and Table 3.

In Table 1 they are organized in numeric order of their addresses. In Table 2 they are organized in groups which refer to the functional blocks of the HMS99C51S/52S/54S/56S/58S. Table 3 illustrates the contents of the SFRs

| Address         | Register                | Contents after<br>Reset             | Address         | Register         | Contents after<br>Reset             |
|-----------------|-------------------------|-------------------------------------|-----------------|------------------|-------------------------------------|
| 80 <sub>H</sub> | P0 <sup>1)</sup>        | FF <sub>H</sub>                     | 88 <sub>H</sub> | TCON 1)          | 00н                                 |
| 81 <sub>H</sub> | SP                      | 07 <sub>H</sub>                     | 89 <sub>H</sub> | TMOD             | 00 <sub>H</sub>                     |
| 82 <sub>H</sub> | DPL                     | 00 <sub>H</sub>                     | 8A <sub>H</sub> | TL0              | 00 <sub>H</sub>                     |
| 83 <sub>H</sub> | DPH                     | 00 <sub>H</sub>                     | 8B <sub>H</sub> | TL1              | 00 <sub>H</sub>                     |
| 84 <sub>H</sub> | reserved                | XX <sub>H</sub> <sup>2)</sup>       | 8C <sub>H</sub> | TH0              | 00 <sub>H</sub>                     |
| 85 <sub>H</sub> | reserved                | XX <sub>H</sub> <sup>2)</sup>       | 8D <sub>H</sub> | TH1              | 00 <sub>H</sub>                     |
| 86 <sub>H</sub> | reserved                | XX <sub>H</sub> <sup>2)</sup>       | 8E <sub>H</sub> | AUXR0            | XXH 2)                              |
| 87 <sub>H</sub> | PCON                    | 0XXX0000 <sub>B</sub> <sup>2)</sup> | 8F <sub>H</sub> | CKCON            | XXXXXXX0 <sub>B</sub> <sup>2)</sup> |
| 90 <sub>H</sub> | <b>P1</b> 1)            | FF <sub>H</sub>                     | 98 <sub>H</sub> | SCON 1)          | 00 <sub>H</sub>                     |
| 91 <sub>H</sub> | reserved                | 00 <sub>H</sub>                     | 99 <sub>H</sub> | SBUF             | XX <sub>H</sub> <sup>2)</sup>       |
| 92 <sub>H</sub> | reserved                | XX <sub>H</sub> <sup>2)</sup>       | 9A <sub>H</sub> | reserved         | XX <sub>H</sub> <sup>2)</sup>       |
| 93 <sub>H</sub> | reserved                | XX <sub>H</sub> <sup>2)</sup>       | 9B <sub>H</sub> | reserved         | XX <sub>H</sub> <sup>2)</sup>       |
| 94 <sub>H</sub> | reserved                | XX <sub>H</sub> <sup>2)</sup>       | 9C <sub>H</sub> | reserved         | XX <sub>H</sub> <sup>2)</sup>       |
| 95 <sub>H</sub> | reserved                | XX <sub>H</sub> <sup>2)</sup>       | 9D <sub>H</sub> | reserved         | XX <sub>H</sub> <sup>2)</sup>       |
| 96 <sub>H</sub> | reserved                | XX <sub>H</sub> <sup>2)</sup>       | 9E <sub>H</sub> | reserved         | XX <sub>H</sub> <sup>2)</sup>       |
| 97 <sub>H</sub> | reserved                | XX <sub>H</sub> <sup>2)</sup>       | 9F <sub>H</sub> | reserved         | XX <sub>H</sub> <sup>2)</sup>       |
| A0 <sub>H</sub> | <b>P2</b> <sup>1)</sup> | FF <sub>H</sub>                     | A8 <sub>H</sub> | IE <sup>1)</sup> | 0X00000 <sub>B</sub> <sup>2)</sup>  |
| A1 <sub>H</sub> | reserved                | XX <sub>H</sub> <sup>2)</sup>       | A9 <sub>H</sub> | reserved         | XX <sub>H</sub> <sup>2)</sup>       |
| A2 <sub>H</sub> | reserved                | XX <sub>H</sub> <sup>2)</sup>       | AA <sub>H</sub> | reserved         | XX <sub>H</sub> <sup>2)</sup>       |
| A3 <sub>H</sub> | reserved                | XX <sub>H</sub> <sup>2)</sup>       | AB <sub>H</sub> | reserved         | XX <sub>H</sub> <sup>2)</sup>       |
| A4 <sub>H</sub> | reserved                | XX <sub>H</sub> <sup>2)</sup>       | AC <sub>H</sub> | reserved         | XX <sub>H</sub> <sup>2)</sup>       |
| A5 <sub>H</sub> | reserved                | XX <sub>H</sub> <sup>2)</sup>       | AD <sub>H</sub> | reserved         | XX <sub>H</sub> <sup>2)</sup>       |
| A6 <sub>H</sub> | reserved                | XX <sub>H</sub> <sup>2)</sup>       | AE <sub>H</sub> | reserved         | XX <sub>H</sub> <sup>2)</sup>       |
| A7 <sub>H</sub> | reserved                | XX <sub>H</sub> <sup>2)</sup>       | AF <sub>H</sub> | reserved         | XX <sub>H</sub> <sup>2)</sup>       |
| B0 <sub>H</sub> | P3 <sup>1)</sup>        | FF <sub>H</sub>                     | B8 <sub>H</sub> | IP <sup>1)</sup> | XX000000 <sub>B</sub> <sup>2)</sup> |
| B1 <sub>H</sub> | reserved                | XX <sub>H</sub> <sup>2)</sup>       | B9 <sub>H</sub> | reserved         | XX <sub>H</sub> <sup>2)</sup>       |
| B2 <sub>H</sub> | reserved                | XX <sub>H</sub> <sup>2)</sup>       | BA <sub>H</sub> | reserved         | XX <sub>H</sub> <sup>2)</sup>       |
| B3 <sub>H</sub> | reserved                | XX <sub>H</sub> <sup>2)</sup>       | BB <sub>H</sub> | reserved         | XX <sub>H</sub> <sup>2)</sup>       |
| B4 <sub>H</sub> | reserved                | XX <sub>H</sub> <sup>2)</sup>       | BC <sub>H</sub> | reserved         | XX <sub>H</sub> <sup>2)</sup>       |
| B5 <sub>H</sub> | reserved                | XX <sub>H</sub> <sup>2)</sup>       | BD <sub>H</sub> | reserved         | XX <sup>2)</sup>                    |
| B6 <sub>H</sub> | reserved                | XX <sub>H</sub> <sup>2)</sup>       | BE <sub>H</sub> | reserved         | XX <sub>H</sub> <sup>2)</sup>       |
| B7 <sub>H</sub> | reserved                | XX <sub>H</sub> <sup>2)</sup>       | BF <sub>H</sub> | reserved         | XX <sub>H</sub> <sup>2)</sup>       |

Table 1. Special Function Registers in Numeric Order of their Addresses (cont'd)



| Address         | Register      | Contents after<br>Reset             | Address         | Register          | Contents after<br>Reset              |
|-----------------|---------------|-------------------------------------|-----------------|-------------------|--------------------------------------|
| C0 <sub>H</sub> | reserved      | XX <sub>H</sub>                     | C8 <sub>H</sub> | T2CON 1)          | 00н                                  |
| C1 <sub>H</sub> | reserved      | XX <sub>H</sub> <sup>2)</sup>       | C9 <sub>H</sub> | T2MOD             | XXXXXXX00 <sub>B</sub> <sup>2)</sup> |
| C2 <sub>H</sub> | reserved      | XX <sub>H</sub> <sup>2)</sup>       | CAH             | RC2L 1)           | 00 <sub>H</sub>                      |
| C3 <sub>H</sub> | reserved      | XX <sub>H</sub> <sup>2)</sup>       | CB <sub>H</sub> | RC2H 1)           | 00 <sub>H</sub>                      |
| C4 <sub>H</sub> | reserved      | XX <sub>H</sub> <sup>2)</sup>       | CCH             | TL2 <sup>1)</sup> | 00 <sub>H</sub>                      |
| C5 <sub>H</sub> | reserved      | XX <sub>H</sub> <sup>2)</sup>       | CD <sub>H</sub> | TH2 <sup>1)</sup> | 00 <sub>H</sub>                      |
| C6 <sub>H</sub> | reserved      | XX <sub>H</sub> <sup>2)</sup>       | CE <sub>H</sub> | reserved          | XX <sub>H</sub> <sup>2)</sup>        |
| C7 <sub>H</sub> | reserved      | XX <sub>H</sub> <sup>2)</sup>       | CF <sub>H</sub> | reserved          | XX <sub>H</sub> <sup>2)</sup>        |
| D0 <sub>H</sub> | <b>PSW</b> 1) | FF <sub>H</sub>                     | D8 <sub>H</sub> | reserved          | XX <sub>H</sub> <sup>2)</sup>        |
| D1 <sub>H</sub> | FCON 3)       | XXXX0000 <sub>B</sub> <sup>2)</sup> | D9 <sub>H</sub> | reserved          | XX <sub>H</sub> <sup>2)</sup>        |
| D2 <sub>H</sub> | reserved      | XX <sub>H</sub> <sup>2)</sup>       | DA <sub>H</sub> | reserved          | XX <sub>H</sub> <sup>2)</sup>        |
| D3 <sub>H</sub> | reserved      | XX <sub>H</sub> <sup>2)</sup>       | DB <sub>H</sub> | reserved          | XX <sub>H</sub> <sup>2)</sup>        |
| D4 <sub>H</sub> | reserved      | XX <sub>H</sub> <sup>2)</sup>       | DC <sub>H</sub> | reserved          | XX <sub>H</sub> <sup>2)</sup>        |
| D5 <sub>H</sub> | reserved      | XX <sub>H</sub> <sup>2)</sup>       | $DD_H$          | reserved          | XX <sub>H</sub> <sup>2)</sup>        |
| D6 <sub>H</sub> | reserved      | XX <sub>H</sub> <sup>2)</sup>       | DE <sub>H</sub> | reserved          | XX <sub>H</sub> <sup>2)</sup>        |
| D7 <sub>H</sub> | reserved      | XX <sub>H</sub> <sup>2)</sup>       | DF <sub>H</sub> | reserved          | XX <sub>H</sub> <sup>2)</sup>        |
| E0 <sub>H</sub> | ACC 1)        | 00 <sub>H</sub>                     | E8 <sub>H</sub> | reserved          | XX <sub>H</sub> <sup>2)</sup>        |
| E1 <sub>H</sub> | reserved      | XX <sub>H</sub> <sup>2)</sup>       | E9 <sub>H</sub> | reserved          | XX <sub>H</sub> <sup>2)</sup>        |
| E2 <sub>H</sub> | reserved      | XX <sub>H</sub> <sup>2)</sup>       | EA <sub>H</sub> | reserved          | XX <sub>H</sub> <sup>2)</sup>        |
| E3 <sub>H</sub> | reserved      | XX <sub>H</sub> <sup>2)</sup>       | EB <sub>H</sub> | reserved          | XX <sub>H</sub> <sup>2)</sup>        |
| E4 <sub>H</sub> | reserved      | XX <sub>H</sub> <sup>2)</sup>       | ECH             | reserved          | XX <sub>H</sub> <sup>2)</sup>        |
| E5 <sub>H</sub> | reserved      | XX <sub>H</sub> <sup>2)</sup>       | ED <sub>H</sub> | reserved          | XX <sub>H</sub> <sup>2)</sup>        |
| E6 <sub>H</sub> | reserved      | XX <sub>H</sub> <sup>2)</sup>       | EEH             | reserved          | XX <sub>H</sub> <sup>2)</sup>        |
| E7 <sub>H</sub> | reserved      | XX <sub>H</sub> <sup>2)</sup>       | EFH             | reserved          | XX <sub>H</sub> <sup>2)</sup>        |
| F0 <sub>H</sub> | <b>B</b> 1)   | 00 <sub>H</sub>                     | F8 <sub>H</sub> | reserved          | XX <sub>H</sub> <sup>2)</sup>        |
| F1 <sub>H</sub> | reserved      | XX <sub>H</sub> <sup>2)</sup>       | F9 <sub>H</sub> | reserved          | XX <sub>H</sub> <sup>2)</sup>        |
| F2 <sub>H</sub> | reserved      | XX <sub>H</sub> <sup>2)</sup>       | FA <sub>H</sub> | reserved          | XX <sub>H</sub> <sup>2)</sup>        |
| F3 <sub>H</sub> | reserved      | XX <sub>H</sub> <sup>2)</sup>       | FB <sub>H</sub> | reserved          | XX <sub>H</sub> <sup>2)</sup>        |
| F4 <sub>H</sub> | reserved      | XX <sub>H</sub> <sup>2)</sup>       | FC <sub>H</sub> | reserved          | XX <sub>H</sub> <sup>2)</sup>        |
| F5 <sub>H</sub> | reserved      | XX <sub>H</sub> <sup>2)</sup>       | FD <sub>H</sub> | reserved          | XX <sub>H</sub> <sup>2)</sup>        |
| F6 <sub>H</sub> | reserved      | XX <sub>H</sub> <sup>2)</sup>       | FE <sub>H</sub> | reserved          | XX <sub>H</sub> <sup>2)</sup>        |
| F7 <sub>H</sub> | reserved      | XX <sub>H</sub> <sup>2)</sup>       | FF <sub>H</sub> | reserved          | XX <sub>H</sub> <sup>2)</sup>        |

Table 1. Special Function Registers in Numeric Order of their Addresses (cont'd)

<sup>1)</sup> Bit-addressable Special Function Register.

<sup>2)</sup> X means that the value is indeterminate and the location is reserved.

<sup>3)</sup> FCON access is reserved for the ISP software.



| Block                                       | Symbol                                   | Name                                                                                                                                                                             | Address                                                                                                                          | Contents<br>after Reset                                                                                        |  |
|---------------------------------------------|------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------|--|
| CPU                                         | ACC<br>B<br>DPH<br>DPL<br>PSW<br>SP      | Accumulator B-Register Data Pointer, High Byte Data Pointer, Low Byte Program Status Word Register Stack Pointer                                                                 | E0 <sub>H</sub> <sup>1)</sup> F0 <sub>H</sub> <sup>1)</sup> 83 <sub>H</sub> 82 <sub>H</sub> D0 <sub>H</sub> <sup>1)</sup>        | 00 <sub>H</sub><br>00 <sub>H</sub><br>00 <sub>H</sub><br>00 <sub>H</sub><br>00 <sub>H</sub><br>07 <sub>H</sub> |  |
| Interrupt System                            | IE<br>IP                                 | Interrupt Enable Register<br>Interrupt Priority Register                                                                                                                         | A8 <sub>H</sub> <sup>1)</sup><br>B8 <sub>H</sub> <sup>1)</sup>                                                                   | 0X000000 <sub>B</sub> <sup>2)</sup><br>XX000000 <sub>B</sub> <sup>2)</sup>                                     |  |
| Ports                                       | P0<br>P1<br>P2<br>P3                     | Port 0<br>Port 1<br>Port 2<br>Port 3                                                                                                                                             | 80 <sub>H</sub> <sup>1)</sup><br>90 <sub>H</sub> <sup>1)</sup><br>A0 <sub>H</sub> <sup>1)</sup><br>B0 <sub>H</sub> <sup>1)</sup> | FF <sub>H</sub><br>FF <sub>H</sub><br>FF <sub>H</sub>                                                          |  |
| Serial Channels                             | PCON 3)<br>SBUF<br>SCON                  | Power Control Register<br>Serial Channel Buffer Reg.<br>Serial Channel 0 Control Reg.                                                                                            | 87 <sub>H</sub><br>99 <sub>H</sub><br><b>98<sub>H</sub></b> <sup>1)</sup>                                                        | 0XXX0000 <sub>B</sub> <sup>2)</sup><br>XX <sub>H</sub> <sup>2)</sup><br>00 <sub>H</sub>                        |  |
| Timer 0/ Timer 1                            | TCON<br>TH0<br>TH1<br>TL0<br>TL1<br>TMOD | Timer 0/1 Control Register Timer 0, High Byte Timer 1, High Byte Timer 0, Low Byte Timer 1, Low Byte Timer Mode Register                                                         | 88 <sub>H</sub> <sup>1)</sup><br>8C <sub>H</sub><br>8D <sub>H</sub><br>8A <sub>H</sub><br>8B <sub>H</sub><br>89 <sub>H</sub>     | 00 <sub>H</sub><br>00 <sub>H</sub><br>00 <sub>H</sub><br>00 <sub>H</sub><br>00 <sub>H</sub>                    |  |
| Timer 2 T2CON T2MOD RC2H RC2L TH2 TL2 AUXR0 |                                          | Timer 2 Control Register Timer 2 Mode Register Timer 2 Reload Capture Reg., High Byte Timer 2 Reload Capture Reg., Low Byte Timer 2, High Byte Timer 2, Low Byte Aux. Register 0 | C8 <sub>H</sub> <sup>1)</sup> C9 <sub>H</sub> CB <sub>H</sub> CA <sub>H</sub> CC <sub>H</sub> 8E <sub>H</sub>                    | 00H<br>00H<br>00H<br>00H<br>00H<br>00H<br>XXXXXXXX0B <sup>2</sup>                                              |  |
| Power Saving<br>Modes                       | PCON 3)                                  | Power Control Register                                                                                                                                                           | 87 <sub>H</sub>                                                                                                                  | 0XXX0000 <sub>B</sub> <sup>2)</sup>                                                                            |  |
| FLASH                                       | FCON 4)                                  | Flash Control Register                                                                                                                                                           | D1 <sub>H</sub>                                                                                                                  | XXXX0000 <sub>B</sub> <sup>2)</sup>                                                                            |  |

Table 2. Special Function Registers - Functional Blocks

- 1) Bit-addressable Special Function register
- 2) X means that the value is indeterminate and the location is reserved
- 3) This special function register is listed repeatedly since some bit of it also belong to other functional blocks
- 4) This special function register is reserved for the ISP software.



| Address         | Register | Bit 7 | 6   | 5   | 4   | 3    | 2   | 1   | 0    |
|-----------------|----------|-------|-----|-----|-----|------|-----|-----|------|
| 80 <sub>H</sub> | P0       |       |     |     |     |      |     |     |      |
| 81 <sub>H</sub> | SP       |       |     |     |     |      |     |     |      |
| 82 <sub>H</sub> | DPL      |       |     |     |     |      |     |     |      |
| 83 <sub>H</sub> | DPH      |       |     |     |     |      |     |     |      |
| 87 <sub>H</sub> | PCON     | SMOD  | -   | -   | -   | GF1  | GF0 | PDE | IDLE |
| 88 <sub>H</sub> | TCON     | TF1   | TR1 | TF0 | TR0 | IE1  | IT1 | IE0 | IT0  |
| 89 <sub>H</sub> | TMOD     | GATE  | C/T | M1  | MT  | GATE | C/T | M1  | MO   |
| 8A <sub>H</sub> | TL0      |       |     |     |     |      |     |     |      |
| 8B <sub>H</sub> | TL1      |       |     |     |     |      |     |     |      |
| 8C <sub>H</sub> | TH0      |       |     |     |     |      |     |     |      |
| 8D <sub>H</sub> | TH1      |       |     |     |     |      |     |     |      |
| 8E <sub>H</sub> | AUXR0    | -     | -   | -   | -   | -    | -   | -   | A0   |
| 8F <sub>H</sub> | CKCON    | -     | -   | -   | -   | -    | -   | -   | X2   |
| 90 <sub>H</sub> | P1       |       |     |     |     |      |     |     |      |
| 98 <sub>H</sub> | SCON     | SM0   | SM1 | SM2 | REN | TB8  | RB8 | TI  | RI   |
| 99 <sub>H</sub> | SBUF     |       |     |     |     |      |     |     |      |
| A0 <sub>H</sub> | P2       |       |     |     |     |      |     |     |      |
| A8 <sub>H</sub> | IE       | EA    | -   | ET2 | ES  | ET1  | EX1 | ET0 | EX0  |
| B0 <sub>H</sub> | P3       |       |     |     |     |      |     |     |      |
| B8 <sub>H</sub> | IP       | -     | -   | PT2 | PS  | PT1  | PX1 | PT0 | PX0  |

Table 3. Contents of SFRs, SFRs in Numeric Order

|  |  |  |  | SFR bit and byte addressable |
|--|--|--|--|------------------------------|
|  |  |  |  | SFR not bit addressable      |

<sup>- :</sup> this bit location is reserved



| Address         | Register | Bit 7  | 6      | 5      | 4        | 3      | 2         | 1       | 0       |
|-----------------|----------|--------|--------|--------|----------|--------|-----------|---------|---------|
| C8 <sub>H</sub> | T2CON    | TF2    | EXF2   | RCLK   | TCLK     | EXEN2  | TR2       | C/T2    | CP/RL2  |
| C9 <sub>H</sub> | T2MOD    | -      | -      | -      | -        | -      | -         | T20E †  | DCEN    |
| $CA_H$          | RC2L     |        |        |        |          |        |           |         |         |
| CB <sub>H</sub> | RC2H     |        |        |        |          |        |           |         |         |
| ССн             | TL2      |        |        |        |          |        |           |         |         |
| CD <sub>H</sub> | TH2      |        |        |        |          |        |           |         |         |
| D0 <sub>H</sub> | PSW      | CY     | AC     | F0     | RS1      | RS0    | OV        | F1      | Р       |
| D1 <sub>H</sub> | FCON     | FRSEL2 | FRSEL1 | FRSEL0 | ERASESEL | ENBOOT | INTROM_EN | PGMSEL1 | PGMSEL0 |
| E0 <sub>H</sub> | ACC      |        |        |        |          |        |           |         |         |
| F0 <sub>H</sub> | В        |        |        |        |          |        |           |         |         |

Table 3. Contents of SFRs, SFRs in Numeric Order (cont'd)





|  |  |  |  | SFR bit and byte addressable |
|--|--|--|--|------------------------------|
|  |  |  |  | SFR not bit addressable      |

-: this bit location is reserved



### X2 MODE

The HMS99C51S/52S/54S/56S/58S core needs only 6 clock periods per machine cycle in X2 mode. This feature called "X2" provides the following advantages:

- Divide frequency crystals by 2 (cheaper crystals) while keeping same CPU power.
- · Save power consumption while keeping same CPU power (oscillator power saving).
- Save power consumption by dividing dynamically operating frequency by 2 in operating and idle modes.
- Increase CPU power by 2 while keeping same crystal frequency.

In order to keep the original C51 compatibility, a divider by 2 is inserted between the XTAL1 signal and the main clock input of the core (phase generator). This divider may be disabled by software.

### **X2** Mode Description

The clock for the whole circuit and peripheral is first divided by two before being used by the CPU core and peripherals. This allows any cyclic ratio to be accepted on XTAL1 input. In X2 mode, as this divider is bypassed, the signals on XTAL1 must have a cyclic ratio between 40 to 60%. Figure 2. shows the clock generation block diagram. X2 bit is validated on XTAL1±2 rising edge to avoid glitches when switching from X2 to STD mode. Figure 3. shows the mode switching waveforms:



Figure 2. Clock Generation Diagram

The X2 bit in the CKCON register allows to switch from 12 clock cycles per instruction to 6 clock cycles and vice versa. At reset, the standard speed is activated (STD mode). Setting this bit activates the X2 feature(X2 mode).

#### **CAUTION**

In order to prevent any incorrect operation while operating in X2 mode, user must be aware that all peripherals using clock frequency as time reference (UART, timers) will have their time reference divided by two. For example a free running timer generating an interrupt every 30 ms will then generate an interrupt every 15 ms. UART with 2400 baud rate will have 4800 baud rate.





Figure 3. Mode Switching Waveforms

.

20 Sep. 2004 Ver 1.01



### **TIMER / COUNTER 0 AND 1**

Timer/Counter 0 and 1 can be used in four operating modes as listed in Table 4:

| Mode | Description                                                                       |      | TM  | IOD |    | Input Clock               |                           |  |
|------|-----------------------------------------------------------------------------------|------|-----|-----|----|---------------------------|---------------------------|--|
| Wode | Description                                                                       | Gate | C/T | M1  | MO | internal                  | external (Max.)           |  |
| 0    | 8-bit timer/counter with a divide-by-32 prescaler                                 | Х    | Х   | 0   | 0  | f <sub>OSC</sub> ÷(12×32) | f <sub>OSC</sub> ÷(24×32) |  |
| 1    | 16-bit timer/counter                                                              | Х    | Χ   | 0   | 1  | f <sub>OSC</sub> ÷12      | f <sub>OSC</sub> ÷24      |  |
| 2    | 8-bit timer/counter with 8-bit auto-reload                                        | Х    | Х   | 1   | 0  | f <sub>OSC</sub> ÷12      | f <sub>OSC</sub> ÷24      |  |
| 3    | Timer/counter 0 used as one 8-bit timer/counter and one 8-bit timer Timer 1 stops | Х    | Х   | 1   | 1  | f <sub>OSC</sub> ÷12      | f <sub>OSC</sub> ÷24      |  |

Table 4. Timer/Counter 0 and 1 Operating Modes

In the "timer" function ( $C/\overline{T}$  = "0") the register is incremented every machine cycle. Therefore the count rate is  $f_{OSC}/12$ .

In the "counter" function the register is incremented in response to a 1-to-0 transition at its corresponding external input pin (P3.4/T0, P3.5/T1). Since it takes two machine cycles to detect a falling edge the max. count rate is  $f_{OSC}/24$ . External inputs  $\overline{INT0}$  and  $\overline{INT1}$  (P3.2, P3.3) can be programmed to function as a gate to facilitate pulse width measurements. Figure 4 illustrates the input clock logic.



Figure 4. Timer/Counter 0 and 1 Input Clock Logic



## TIMER 2

Timer 2 is a 16-bit timer/Counter with an up/down count feature. It can operate either as timer or as an event counter which is selected by bit  $C/\overline{T2}$  (T2CON.1). It has three operating modes as shown in Table 5.

|                        | T2CON              |            |     | T2M<br>OD | T2C<br>ON | P1.      |                                             | Input Clock           |                               |
|------------------------|--------------------|------------|-----|-----------|-----------|----------|---------------------------------------------|-----------------------|-------------------------------|
| Mode                   | RCLK<br>or<br>TCLK | CP/<br>RL2 | TR2 | DCE<br>N  | EXE<br>N2 | T2<br>EX | Remarks                                     | internal              | external<br>(P1.0/T2)         |
| 16-bit Auto-<br>Reload | 0                  | 0          | 1   | 0         | 0         | Х        | reload upon over-<br>flow                   | f <sub>OSC</sub> ÷ 12 | Max.<br>f <sub>OSC</sub> ÷24  |
|                        | 0                  | 0          | 1   | 0         | 1         | <b>\</b> | reload trigger<br>(falling edge)            |                       |                               |
|                        | 0                  | 0          | 1   | 1         | Х         | 0        | Down counting                               |                       |                               |
|                        | 0                  | 0          | 1   | 1         | Х         | 1        | Up counting                                 |                       |                               |
| 16-bit<br>Capture      | 0                  | 1          | 1   | Х         | 0         | Х        | 16 bit Timer/<br>Counter (only up-          | f <sub>OSC</sub> ÷ 12 | Max.<br>f <sub>OSC</sub> ÷ 24 |
|                        | 0                  | 1          | 1   | х         | 1         | <b>\</b> | counting)<br>capture TH2,TL2<br>→ RC2H,RC2L |                       |                               |
| Baud Rate<br>Generator | 1                  | Х          | 1   | Х         | 0         | Х        | no overflow interrupt request               | f <sub>OSC</sub> ÷ 12 | Max.<br>f <sub>OSC</sub> ÷ 24 |
|                        | 1                  | X          | 1   | Х         | 1         | <b>\</b> | (TF2) extra external interrupt ("Timer 2")  |                       |                               |
| Off                    | Х                  | Х          | 0   | Х         | Х         | Х        | Timer 2 stops                               | -                     | -                             |

Table 5. Timer/Counter 2 Operating Modes

Note: ↓ = ¬Lfalling edge



# **SERIAL INTERFACE (UART)**

The serial port is full duplex and can operate in four modes (one synchronous mode, three asynchronous modes) as illustrated in Table 6. The possible baud rates can be calculated using the formulas given in Table 7.

| Mode  | SCON |     | Baudrate                                     | Description                                                                                                       |  |  |  |
|-------|------|-----|----------------------------------------------|-------------------------------------------------------------------------------------------------------------------|--|--|--|
| Wiode | SM0  | SM1 | Baudrate                                     | ·                                                                                                                 |  |  |  |
| 0     | 0    | 0   | f <sub>OSC</sub><br>12                       | Serial data enters and exits through RxD. TxD outputs the shift clock. 8-bit are transmitted/received (LSB first) |  |  |  |
| 1     | 0    | 1   | Timer 1/2 overflow rate                      | 8-bit UART<br>10 bits are transmitted (through TxD) or<br>received (RxD)                                          |  |  |  |
| 2     | 1    | 0   | $\frac{f_{OSC}}{32}$ or $\frac{f_{OSC}}{64}$ | 9-bit UART<br>11 bits are transmitted (TxD) or received (RxD)                                                     |  |  |  |
| 3     | 1    | 1   | Timer 1/2 overflow rate                      | 9-bit UART<br>Like mode 2 except the variable baud rate                                                           |  |  |  |

**Table 6. UART Operating Modes** 

| Baud Rate<br>derived from               | Interface Mode | Baudrate                                                             |  |  |
|-----------------------------------------|----------------|----------------------------------------------------------------------|--|--|
| Oscillator                              | 0              | f <sub>osc</sub><br>12                                               |  |  |
| Oscillator                              | timer) vith    | $\frac{2^{SMOD}}{64} \times f_{OSC}$                                 |  |  |
| Timer 1 (16-bit timer)                  | 1,3            | $\frac{2^{SMOD}}{32} \times (Timer \ 1 \ overflow)$                  |  |  |
| (8-bit timer with<br>8-bit auto reload) | 1,3            | $\frac{2^{SMOD}}{32} \times \frac{f_{OSC}}{12 \times [256 - (TH1)]}$ |  |  |
| Timer 2                                 | 1,3            | $\frac{f_{\text{OSC}}}{32 \times [65536 - (RC2H, RC2L)]}$            |  |  |

Table 7. Formulas for Calculating Baud rates



## **INTERRUPT SYSTEM**

The HMS99C51S/52S/54S/56S/58S provide 6 (above 8K bytes ROM version) interrupt sources with two priority levels. Figure 5 gives a general overview of the interrupt sources and illustrates the request and control flags.



Figure 5. Interrupt Request Sources



| Source (Request Flags) | Vectors               | Vector Address    |
|------------------------|-----------------------|-------------------|
| RESET                  | RESET                 | 0000 <sub>H</sub> |
| IE0                    | External interrupt 0  | 0003 <sub>H</sub> |
| TF0                    | Timer 0 interrupt     | 000B <sub>H</sub> |
| IE1                    | External interrupt 1  | 0013 <sub>H</sub> |
| TF1                    | Timer 1 interrupt     | 001B <sub>H</sub> |
| RI + TI                | Serial port interrupt | 0023 <sub>H</sub> |
| TF2 + EXF2             | Timer 2 interrupt     | 002B <sub>H</sub> |

**Table 8. Interrupt Sources and their Corresponding Interrupt Vectors** 

A low-priority interrupt can itself be interrupted by a high-priority interrupt, but not by another low priority interrupt. A high-priority interrupt cannot be interrupted by any other interrupt source.

If two requests of different priority level are received simultaneously, the request of higher priority is serviced. If requests of the same priority are received simultaneously, an internal polling sequence determines which request is serviced. Thus within each priority level there is a second priority structure determined by the polling sequence as shown in Table 9.

| Interrup             | t Source   | Priority     |
|----------------------|------------|--------------|
| External Interrupt 0 | IE0        | High         |
| Timer 0 Interrupt    | TF0        | Į.           |
| External Interrupt 1 | IE1        | $\downarrow$ |
| Timer 1 Interrupt    | TF1        | $\downarrow$ |
| Serial Channel       | RI + TI    | $\downarrow$ |
| Timer 2 Interrupt    | TF2 + EXF2 | Low          |

Table 9. Interrupt Priority-Within-Level



# **Power Saving Modes**

Two power down modes are available, the Idle Mode and Power Down Mode.

The bits PDE and IDLE of the register PCON select the Power Down mode or the Idle mode, respectively. If the Power Down mode and the Idle mode are set at the same time, the Power Down mode takes precedence. Table 10 gives a general overview of the power saving modes.

| Mode            | Entering<br>Instruction<br>Example | Leaving by                              | Remarks                                                                                                                                         |
|-----------------|------------------------------------|-----------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| Idle mode       | ORL PCON, #01H                     | - Enabled interrupt<br>- Hardware Reset | CPU is gated off CPU status registers maintain their data. Peripherals are active                                                               |
| Power-Down mode | ORL PCON, #02H                     | Hardware Reset                          | Oscillator is stopped, contents of on-<br>chip RAM and SFR's are maintained<br>(leaving Power Down Mode means<br>redefinition of SFR contents). |

**Table 10. Power Saving Modes Overview** 

In the Power Down mode of operation,  $V_{CC}$  can be reduced to minimize power consumption. It must be ensured, however, that  $V_{CC}$  is not reduced before the Power Down mode is invoked, and that  $V_{CC}$  is restored to its normal operating level, before the Power Down mode is terminated. The reset signal that terminates the Power Down mode also restarts the oscillator. The reset should not be activated before  $V_{CC}$  is restored to its normal operating level and must be held active long enough to allow the oscillator to restart and stabilize (similar to power-on reset).



### **ELECTRICAL CHARACTERISTICS**

### **Absolute Maximum Ratings**

| Ambient temperature under bias (T <sub>A</sub> )                          | -40 to +85 °C           |
|---------------------------------------------------------------------------|-------------------------|
| Storage temperature (T <sub>ST</sub> )                                    | 65 to + 150 °C          |
| Voltage on V <sub>CC</sub> pins with respect to ground (V <sub>SS</sub> ) | -0.5V to 6.5V           |
| Voltage on any pin with respect to ground (VSS)                           | 0.5V to $V_{CC} + 0.5V$ |
| Input current on any pin during overload condition                        | 10mA to +10mA           |
| Absolute sum of all input currents during overload condition              | 100mA                   |
| Power dissipation                                                         | 200mW                   |

**Note:** Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage of the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for longer periods may affect device reliability. During overload conditions ( $V_{IN} > V_{CC}$  or  $V_{IN} < V_{SS}$ ) the Voltage on  $V_{CC}$  pins with respect to ground ( $V_{SS}$ ) must not exceed the values defined by the absolute maximum ratings.



## **DC Characteristics**

### DC Characteristics for HMS99C51S/52S/54S/56S/58S

 $V_{CC}\!\!=5V$  + 10%, -15%,  $V_{SS}\!\!=\!\!0V,~T_{A}\!\!=$  -40°C to 85 °C

| Daman dan                                                                                                                                                                                                                                            | 0                                      | Limit                     | Values                               | Un                               | Total Constitutions                                                                                                                                                                                                                    |  |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------|---------------------------|--------------------------------------|----------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Parameter                                                                                                                                                                                                                                            | Symbol                                 | Min.                      | Max.                                 | it                               | Test Conditions                                                                                                                                                                                                                        |  |
| Input low voltage (except EA, RESET)                                                                                                                                                                                                                 | V <sub>IL</sub>                        | -0.5                      | 0.2V <sub>CC</sub> - 0.1             | V                                | V <sub>CC</sub> = 5.5V                                                                                                                                                                                                                 |  |
| Input low voltage (EA)                                                                                                                                                                                                                               | V <sub>IL1</sub>                       | -0.5                      | 0.2V <sub>CC</sub> - 0.1             | V                                | V <sub>CC</sub> = 5.5V                                                                                                                                                                                                                 |  |
| Input low voltage (RESET)                                                                                                                                                                                                                            | V <sub>IL2</sub>                       | -0.5                      | 0.2V <sub>CC</sub> + 0.1             | V                                | V <sub>CC</sub> = 5.5V                                                                                                                                                                                                                 |  |
| Input high voltage (except XTAL1, EA, RESET)                                                                                                                                                                                                         | V <sub>IH</sub>                        | 0.2V <sub>CC</sub> + 0.9  | V <sub>CC</sub> + 0.5                | ٧                                | V <sub>CC</sub> = 4.5V                                                                                                                                                                                                                 |  |
| Input high voltage to XTAL1                                                                                                                                                                                                                          | V <sub>IH1</sub>                       | 0.7V <sub>CC</sub>        | V <sub>CC</sub> + 0.5                | V                                | V <sub>CC</sub> = 4.5V                                                                                                                                                                                                                 |  |
| Input high voltage to $\overline{EA}$ , RESET                                                                                                                                                                                                        | V <sub>IH2</sub>                       | 0.6V <sub>CC</sub>        | V <sub>CC</sub> + 0.5                | V                                | V <sub>CC</sub> = 4.5V                                                                                                                                                                                                                 |  |
| Output low voltage (ports 1, 2, 3)                                                                                                                                                                                                                   | V <sub>OL</sub>                        | -                         | 0.45                                 | V                                | V <sub>CC</sub> = 5.5V, I <sub>OL</sub> = 1.6mA <sup>1)</sup>                                                                                                                                                                          |  |
| Output low voltage (port 0, ALE, PSEN)                                                                                                                                                                                                               | V <sub>OL1</sub>                       | -                         | 0.45                                 | ٧                                | V <sub>CC</sub> = 5.5V, I <sub>OL</sub> = 3.2mA <sup>1)</sup>                                                                                                                                                                          |  |
| Output high voltage (ports 1, 2, 3)                                                                                                                                                                                                                  | V <sub>OH</sub>                        | 2.4<br>0.9V <sub>CC</sub> | -                                    | V                                | V <sub>CC</sub> = 4.5V, I <sub>OH</sub> = -80μA<br>V <sub>CC</sub> = 4.5V, I <sub>OH</sub> = -10μA                                                                                                                                     |  |
| Output high voltage<br>(port 0 in external bus<br>mode, ALE, PSEN)                                                                                                                                                                                   | V <sub>OH1</sub>                       | 2.4<br>0.9V <sub>CC</sub> | -                                    | ٧                                | V <sub>CC</sub> = 4.5V, I <sub>OH</sub> = -800μA <sup>2)</sup><br>V <sub>CC</sub> = 4.5V, I <sub>OH</sub> = -80μA <sup>2)</sup>                                                                                                        |  |
| Logic 0 input current (ports 1, 2, 3)                                                                                                                                                                                                                | I <sub>IL</sub>                        | -10                       | -65                                  | μА                               | V <sub>IN</sub> = 0.45V                                                                                                                                                                                                                |  |
| Logical 1-to-0 transition current (ports 1, 2, 3)                                                                                                                                                                                                    | I <sub>TL</sub>                        | -65                       | -650                                 | μА                               | V <sub>IN</sub> = 2.0V                                                                                                                                                                                                                 |  |
| Input leakage current (port 0, EA)                                                                                                                                                                                                                   | ILI                                    | -                         | ±1                                   | μА                               | 0.45 < V <sub>IN</sub> < V <sub>CC</sub>                                                                                                                                                                                               |  |
| Pin capacitance                                                                                                                                                                                                                                      | C <sub>IO</sub>                        | -                         | 10                                   | pF                               | f <sub>C</sub> = 1MHz<br>T <sub>A</sub> = 25°C                                                                                                                                                                                         |  |
| Power supply current: Active mode, 4MHz <sup>3)</sup> Idle mode, 4MHz <sup>4)</sup> Active mode, 24 MHz <sup>4)</sup> Idle mode, 24MHz <sup>4)</sup> Active mode, 40 MHz <sup>4)</sup> Idle mode, 40 MHz <sup>4)</sup> Power Down Mode <sup>4)</sup> | Icc<br>Icc<br>Icc<br>Icc<br>Icc<br>Icc | -                         | 8<br>4<br>25<br>10<br>30<br>15<br>50 | mA<br>mA<br>mA<br>mA<br>mA<br>mA | V <sub>CC</sub> = 5V <sup>4</sup> )<br>V <sub>CC</sub> = 5V <sup>5</sup> )<br>V <sub>CC</sub> = 5V <sup>4</sup> )<br>V <sub>CC</sub> = 5V <sup>5</sup> )<br>V <sub>CC</sub> = 5V <sup>4</sup> )<br>V <sub>CC</sub> = 5V <sup>6</sup> ) |  |



- 1) Capacitive loading on ports 0 and 2 may cause spurious noise pulses to be superimposed on the V<sub>OL</sub> of ALE and port 3. The noise is due to external bus capacitance discharging into the port 0 and port 2 pins when these pins make 1-to-0 transitions during bus operation. In the worst case(capacitive loading: > 50pF at 3.3V, > 100pF at 5V), the noise pulse on ALE line may exceed 0.8V. In such cases it may be desirable to qualify ALE with a schmitt-trigger, or use an address latch with a schmitt-trigger strobe input.
- 2) Capacitive loading on ports 0 and 2 may cause the V<sub>OH</sub> on ALE and  $\overline{\text{PSEN}}$  to momentarily fall below the 0.9V<sub>CC</sub> specification when the address lines are stabilizing.
- 3)  $I_{CC}$  Max. at other frequencies is given by:

active mode:  $I_{CC} = 1.27 \times f_{OSC} + 5.73$ 

dle mode:  $I_{CC} = 0.28 \times f_{OSC} + 1.45$  (except OTP devices)

where  $f_{OSC}$  is the oscillator frequency in MHz.  $I_{CC}$  values are given in mA and measured at  $V_{CC}$  = 5V.

4) I<sub>CC</sub> (active mode) is measured with:

XTAL1 driven with  $t_{CLCH}$ ,  $t_{CHCL}$  = 5ns,  $V_{IL}$  =  $V_{SS}$  + 0.5V,  $V_{IH}$  =  $V_{CC}$  - 0.5V; XTAL2 = N.C.;

EA = Port0 = RESET = V<sub>CC</sub>; all other pins are disconnected. I<sub>CC</sub> would be slightly higher if a crystal oscillator is used (appr. 1mA).

5)  $I_{CC}$  (Idle mode) is measured with all output pins disconnected and with all peripherals disabled;

XTAL1 driven with  $t_{CLCH}$ ,  $t_{CHCL}$  = 5ns,  $V_{IL}$  =  $V_{SS}$  + 0.5V,  $V_{IH}$  =  $V_{CC}$  - 0.5V; XTAL2 = N.C.;

RESET =  $\overline{EA}$  = V<sub>SS</sub>; Port0 = V<sub>CC</sub>; all other pins are disconnected;

6) I<sub>PD</sub> (Power Down Mode) is measured under following conditions:

EA = Port0 = V<sub>CC</sub>; RESET = V<sub>SS</sub>; XTAL2 = N.C.; XTAL1 = V<sub>SS</sub>; all other pins are disconnected.



### **AC Characteristics**

#### **Explanation of the AC Symbols**

Each timing symbol has 5 characters. The first character is always a 't' (stand for time). The other characters, depending on their positions, stand for the name of a signal or the logical status of that signal. The following is a list of all the characters and what they stand for.

 A: Address
 T: Time

 C: Clock
 V: Valid

 D: Input Data
 W: WR signal

H: Logic level HIGH X: No longer a valid logic level

I: Instruction (program memory contents)

Z: Float

L: Logic level LOW, or ALE

P: PSEN For example,

Q:  $\underline{\text{Out}}$ put Data  $t_{\text{AVLL}}$  = Time from Address Valid to  $\underline{\text{ALE}}$  Low R:  $\overline{\text{RD}}$  signal  $t_{\text{LLPL}}$  = Time from ALE Low to  $\overline{\text{PSEN}}$  Low

#### AC Characteristics for HMS99C51S/52S/54S/56S/58S (12MHz version)

 $V_{CC}$ = 5V :  $V_{CC}$ = 5V + 10%, - 15%,  $V_{SS}$ = 0V,  $T_A$ = -40°C to 85°C

( $C_L$  for port 0, ALE and  $\overline{PSEN}$  outputs = 100pF,  $C_L$  for all other outputs = 80pF)

Variable clock: Vcc = 5V : 1/t<sub>CLCL</sub> = 3.5 MHz to 12 MHz

#### **External Program Memory Characteristics**

| Parameter                          | Symbol              | 12 MHz ( | Oscillator | Variable<br>1/t <sub>CLCL</sub> = 3 | Unit                    |    |
|------------------------------------|---------------------|----------|------------|-------------------------------------|-------------------------|----|
|                                    |                     | Min.     | Max.       | Min.                                | Max.                    |    |
| ALE pulse width                    | t <sub>LHLL</sub>   | 127      | -          | 2t <sub>CLCL</sub> -40              | -                       | ns |
| Address setup to ALE               | t <sub>AVLL</sub>   | 43       | -          | t <sub>CLCL</sub> -40               | -                       | ns |
| Address hold after ALE             | t <sub>LLAX</sub>   | 30       | -          | t <sub>CLCL</sub> -53               | -                       | ns |
| ALE low to valid instruction in    | t <sub>LLIV</sub>   | -        | 233        | -                                   | 4t <sub>CLCL</sub> -100 | ns |
| ALE to PSEN                        | t <sub>LLPL</sub>   | 58       | -          | t <sub>CLCL</sub> -25               | -                       | ns |
| PSEN pulse width                   | t <sub>PLPH</sub>   | 215      | -          | 3t <sub>CLCL</sub> -35              | -                       | ns |
| PSEN to valid instruction in       | t <sub>PLIV</sub>   | -        | 150        | -                                   | 3t <sub>CLCL</sub> -100 | ns |
| Input instruction hold after PSEN  | t <sub>PXIX</sub>   | 0        | -          | 0                                   | -                       | ns |
| Input instruction float after PSEN | t <sub>PXIZ</sub> † | -        | 63         | -                                   | t <sub>CLCL</sub> -20   | ns |
| Address valid after PSEN           | t <sub>PXAV</sub> † | 75       | -          | t <sub>CLCL</sub> -8                | -                       | ns |
| Address to valid instruction in    | t <sub>AVIV</sub>   | -        | 302        | -                                   | 5t <sub>CLCL</sub> -115 | ns |
| Address float to PSEN              | t <sub>AZPL</sub>   | 0        | -          | 0                                   | -                       | ns |

<sup>†</sup> Interfacing the HMS99C51S/52S/54S/56S/58S to devices with float times up to 75 ns is permissible. This limited bus contention will not cause any damage to port 0 Drivers.



## AC Characteristics for HMS99C51S/52S/54S/56S/58S (12MHz)

## **External Data Memory Characteristics**

| Parameter                   | Symbol             | 12 MHz ( | Oscillator | Variable (<br>1/t <sub>CLCL</sub> = 3. | Unit                    |    |
|-----------------------------|--------------------|----------|------------|----------------------------------------|-------------------------|----|
|                             |                    | Min.     | Max.       | Min.                                   | Max.                    |    |
| RD pulse width              | t <sub>RLRH</sub>  | 400      | -          | 6t <sub>CLCL</sub> -100                | -                       | ns |
| WR pulse width              | t <sub>WLWH</sub>  | 400      | -          | 6t <sub>CLCL</sub> -100                | -                       | ns |
| Address hold after ALE      | t <sub>LLAX2</sub> | 53       | -          | t <sub>CLCL</sub> -30                  | -                       | ns |
| RD to valid data in         | t <sub>RLDV</sub>  | -        | 252        | -                                      | 5t <sub>CLCL</sub> -165 | ns |
| Data hold after RD          | t <sub>RHDX</sub>  | 0        | -          | 0                                      | -                       | ns |
| Data float after RD         | t <sub>RHDZ</sub>  | -        | 97         | -                                      | 2t <sub>CLCL</sub> -70  | ns |
| ALE to valid data in        | t <sub>LLDV</sub>  | -        | 517        | -                                      | 8t <sub>CLCL</sub> -150 | ns |
| Address to valid data in    | t <sub>AVDV</sub>  | -        | 585        | -                                      | 9t <sub>CLCL</sub> -165 | ns |
| ALE to WR or RD             | t <sub>LLWL</sub>  | 200      | 300        | 3t <sub>CLCL</sub> -50                 | 3t <sub>CLCL</sub> +50  | ns |
| Address valid to WR or RD   | t <sub>AVWL</sub>  | 203      | -          | 4t <sub>CLCL</sub> -130                | -                       | ns |
| WR or RD high to ALE high   | t <sub>WHLH</sub>  | 43       | 123        | t <sub>CLCL</sub> -40                  | t <sub>CLCL</sub> +40   | ns |
| Data valid to WR transition | t <sub>QVWX</sub>  | 33       | -          | t <sub>CLCL</sub> -50                  | -                       | ns |
| Data setup before WR        | t <sub>QVWH</sub>  | 433      | -          | 7t <sub>CLCL</sub> -150                | -                       | ns |
| Data hold after WR          | t <sub>WHQX</sub>  | 33       | -          | t <sub>CLCL</sub> -50                  | -                       | ns |
| Address float after RD      | t <sub>RLAZ</sub>  | -        | 0          | -                                      | 0                       | ns |

## **Advance Information (12MHz)**

### **External Clock Drive**

| Parameter                               | Symbol            | Variable<br>(Freq. = 3.9 | Unit          |    |
|-----------------------------------------|-------------------|--------------------------|---------------|----|
|                                         |                   | Min.                     | Max.          |    |
| Oscillator period (V <sub>CC</sub> =5V) | tclcl             | 83.3                     | 285.7         | ns |
| High time                               | tcHCX             | 20                       | tolol - tolox | ns |
| Low time                                | t <sub>CLCX</sub> | 20                       | tclcl - tchcx | ns |
| Rise time                               | tclch             | -                        | 20            | ns |
| Fall time                               | t <sub>CHCL</sub> | -                        | 20            | ns |



### AC Characteristics for HMS99C51S/52S/54S/56S/58S (24MHz version)

 $V_{CC} = 5V + 10\%, -15\%, V_{SS} = 0V, \ T_A = -40^{\circ}C \ to \ 85^{\circ}C$  (C<sub>L</sub> for port 0. ALE and  $\overline{PSEN}$  outputs = 100pF; C<sub>L</sub> for all other outputs = 80pF)

### **External Program Memory Characteristics**

| Parameter                          | Symbol              | 24 MHz Oscillator |      | Variable Oscillator<br>1/t <sub>CLCL</sub> = 3.5 to 24MHz |                        | Unit |
|------------------------------------|---------------------|-------------------|------|-----------------------------------------------------------|------------------------|------|
|                                    |                     | Min.              | Max. | Min.                                                      | Max.                   |      |
| ALE pulse width                    | t <sub>LHLL</sub>   | 43                | -    | 2t <sub>CLCL</sub> -40                                    | -                      | ns   |
| Address setup to ALE               | t <sub>AVLL</sub>   | 17                | -    | t <sub>CLCL</sub> -25                                     | -                      | ns   |
| Address hold after ALE             | t <sub>LLAX</sub>   | 17                | -    | t <sub>CLCL</sub> -25                                     | -                      | ns   |
| ALE low to valid instruction in    | t <sub>LLIV</sub>   | -                 | 80   | -                                                         | 4t <sub>CLCL</sub> -87 | ns   |
| ALE to PSEN                        | t <sub>LLPL</sub>   | 22                | -    | t <sub>CLCL</sub> -20                                     | -                      | ns   |
| PSEN pulse width                   | t <sub>PLPH</sub>   | 95                | -    | 3t <sub>CLCL</sub> -30                                    | -                      | ns   |
| PSEN to valid instruction in       | t <sub>PLIV</sub>   | -                 | 60   | -                                                         | 3t <sub>CLCL</sub> -65 | ns   |
| Input instruction hold after PSEN  | t <sub>PXIX</sub>   | 0                 | -    | 0                                                         | -                      | ns   |
| Input instruction float after PSEN | t <sub>PXIZ</sub> † | -                 | 32   | -                                                         | t <sub>CLCL</sub> -10  | ns   |
| Address valid after PSEN           | t <sub>PXAV</sub> † | 37                | -    | t <sub>CLCL</sub> -5                                      | -                      | ns   |
| Address to valid instruction in    | t <sub>AVIV</sub>   | -                 | 148  | -                                                         | 5t <sub>CLCL</sub> -60 | ns   |
| Address float to PSEN              | t <sub>AZPL</sub>   | 0                 | -    | 0                                                         | -                      | ns   |

<sup>&</sup>lt;sup>†</sup> Interfacing the HMS99C51S/52S/54S/56S/58S to devices with float times up to 35 ns is permissible. This limited bus contention will not cause any damage to port 0 Drivers.



## AC Characteristics for HMS99C51S/52S/54S/56S/58S(24MHz)

## **External Data Memory Characteristics**

| Parameter                   | Symbol             | 24 MHz Oscillator |      | Variable Oscillator<br>1/t <sub>CLCL</sub> = 3.5 to 24MHz |                         | Unit |  |
|-----------------------------|--------------------|-------------------|------|-----------------------------------------------------------|-------------------------|------|--|
|                             |                    | Min.              | Max. | Min.                                                      | Max.                    |      |  |
| RD pulse width              | t <sub>RLRH</sub>  | 180               | -    | 6t <sub>CLCL</sub> -70                                    | -                       | ns   |  |
| WR pulse width              | t <sub>WLWH</sub>  | 180               | -    | 6t <sub>CLCL</sub> -70                                    | -                       | ns   |  |
| Address hold after ALE      | t <sub>LLAX2</sub> | 15                | -    | t <sub>CLCL</sub> -27                                     | -                       | ns   |  |
| RD to valid data in         | t <sub>RLDV</sub>  | -                 | 118  | -                                                         | 5t <sub>CLCL</sub> -90  | ns   |  |
| Data hold after RD          | t <sub>RHDX</sub>  | 0                 | -    | 0                                                         | -                       | ns   |  |
| Data float after RD         | t <sub>RHDZ</sub>  | -                 | 63   | -                                                         | 2t <sub>CLCL</sub> -20  | ns   |  |
| ALE to valid data in        | t <sub>LLDV</sub>  | -                 | 200  | -                                                         | 8t <sub>CLCL</sub> -133 | ns   |  |
| Address to valid data in    | t <sub>AVDV</sub>  | -                 | 220  | -                                                         | 9t <sub>CLCL</sub> -155 | ns   |  |
| ALE to WR or RD             | t <sub>LLWL</sub>  | 75                | 175  | 3t <sub>CLCL</sub> -50                                    | 3t <sub>CLCL</sub> +50  | ns   |  |
| Address valid to WR or RD   | t <sub>AVWL</sub>  | 67                | -    | 4t <sub>CLCL</sub> -97                                    | -                       | ns   |  |
| WR or RD high to ALE high   | twhLH              | 17                | 67   | t <sub>CLCL</sub> -25                                     | t <sub>CLCL</sub> +25   | ns   |  |
| Data valid to WR transition | t <sub>QVWX</sub>  | 5                 | -    | t <sub>CLCL</sub> -37                                     | -                       | ns   |  |
| Data setup before WR        | t <sub>QVWH</sub>  | 170               | -    | 7t <sub>CLCL</sub> -122                                   | -                       | ns   |  |
| Data hold after WR          | t <sub>WHQX</sub>  | 15                | -    | t <sub>CLCL</sub> -27                                     | -                       | ns   |  |
| Address float after RD      | t <sub>RLAZ</sub>  | -                 | 0    | -                                                         | 0                       | ns   |  |

## **Advance Information (24MHz)**

## **External Clock Drive**

| Parameter         | Symbol            | Variable (<br>(Freq. = 3.5 | Unit                                  |    |  |
|-------------------|-------------------|----------------------------|---------------------------------------|----|--|
|                   | -                 | Min.                       | Max.                                  | İ  |  |
| Oscillator period | tclcl             | 41.7                       | 285.7                                 | ns |  |
| High time         | t <sub>CHCX</sub> | 12                         | t <sub>CLCL</sub> - t <sub>CLCX</sub> | ns |  |
| Low time          | t <sub>CLCX</sub> | 12                         | t <sub>CLCL</sub> - t <sub>CHCX</sub> | ns |  |
| Rise time         | tclch             | - 12                       |                                       | ns |  |
| Fall time         | t <sub>CHCL</sub> | -                          | 12                                    | ns |  |



## AC Characteristics for HMS99C51S/52S/54S/56S/58S(40MHz version)

 $V_{CC} = 5V + 10\%, -15\%, V_{SS} = 0V, \ T_A = -40^{\circ}C \ to \ 85^{\circ}C$  (C<sub>L</sub> for port 0, ALE and  $\overline{PSEN}$  outputs = 100pF, C<sub>L</sub> for all other outputs = 80pF)

#### **External Program Memory Characteristics**

| Parameter                          | Symbol              | 40 MHz Oscillator |      | Variable Oscillator<br>1/t <sub>CLCL</sub> = 3.5 to 40MHz |                        | Unit |  |
|------------------------------------|---------------------|-------------------|------|-----------------------------------------------------------|------------------------|------|--|
|                                    |                     | Min.              | Max. | Min.                                                      | Max.                   |      |  |
| ALE pulse width                    | t <sub>LHLL</sub>   | 40                | -    | 2t <sub>CLCL</sub> -20                                    | -                      | ns   |  |
| Address setup to ALE               | t <sub>AVLL</sub>   | 10                | -    | t <sub>CLCL</sub> -20                                     | -                      | ns   |  |
| Address hold after ALE             | t <sub>LLAX</sub>   | 10                | -    | t <sub>CLCL</sub> -20                                     | -                      | ns   |  |
| ALE low to valid instruction in    | t <sub>LLIV</sub>   | -                 | 56   | -                                                         | 4t <sub>CLCL</sub> -65 | ns   |  |
| ALE to PSEN                        | t <sub>LLPL</sub>   | 15                | -    | t <sub>CLCL</sub> -15                                     | -                      | ns   |  |
| PSEN pulse width                   | t <sub>PLPH</sub>   | 80                | -    | 3t <sub>CLCL</sub> -20                                    | -                      | ns   |  |
| PSEN to valid instruction in       | t <sub>PLIV</sub>   | -                 | 35   | -                                                         | 3t <sub>CLCL</sub> -55 | ns   |  |
| Input instruction hold after PSEN  | t <sub>PXIX</sub>   | 0                 | -    | 0                                                         | -                      | ns   |  |
| Input instruction float after PSEN | t <sub>PXIZ</sub> † | -                 | 20   | -                                                         | t <sub>CLCL</sub> -10  | ns   |  |
| Address valid after PSEN           | t <sub>PXAV</sub> † | 25                | -    | t <sub>CLCL</sub> -5                                      | -                      | ns   |  |
| Address to valid instruction in    | t <sub>AVIV</sub>   | -                 | 91   | -                                                         | 5t <sub>CLCL</sub> -60 | ns   |  |
| Address float to PSEN              | tazpl               | 0                 | -    | 0                                                         | -                      | ns   |  |

<sup>&</sup>lt;sup>†</sup> Interfacing the HMS99C51S/52S/54S/56S/58S to devices with float times up to 20 ns is permissible. This limited bus contention will not cause any damage to port 0 Drivers.



## AC Characteristics for HMS99C51S/52S/54S/56S/58S(40MHz)

## **External Data Memory Characteristics**

| Parameter                   | Symbol             | at 40 MHz Clock |      | Variable Clock<br>1/t <sub>CLCL</sub> = 3.5 to 40MHz |                        | Unit |  |
|-----------------------------|--------------------|-----------------|------|------------------------------------------------------|------------------------|------|--|
|                             |                    | Min.            | Max. | Min.                                                 | Max.                   |      |  |
| RD pulse width              | t <sub>RLRH</sub>  | 132             | -    | 6t <sub>CLCL</sub> -50                               | -                      | ns   |  |
| WR pulse width              | t <sub>WLWH</sub>  | 132             | -    | 6t <sub>CLCL</sub> -50                               | -                      | ns   |  |
| Address hold after ALE      | t <sub>LLAX2</sub> | 10              | -    | t <sub>CLCL</sub> -20                                | -                      | ns   |  |
| RD to valid data in         | t <sub>RLDV</sub>  | -               | 81   | -                                                    | 5t <sub>CLCL</sub> -70 | ns   |  |
| Data hold after RD          | t <sub>RHDX</sub>  | 0               | -    | 0                                                    | -                      | ns   |  |
| Data float after RD         | t <sub>RHDZ</sub>  | -               | 46   | -                                                    | 2t <sub>CLCL</sub> -15 | ns   |  |
| ALE to valid data in        | tLLDV              | -               | 153  | -                                                    | 8t <sub>CLCL</sub> -90 | ns   |  |
| Address to valid data in    | t <sub>AVDV</sub>  | -               | 183  | -                                                    | 9t <sub>CLCL</sub> -90 | ns   |  |
| ALE to WR or RD             | t <sub>LLWL</sub>  | 71              | 111  | 3t <sub>CLCL</sub> -20                               | 3t <sub>CLCL</sub> +20 | ns   |  |
| Address valid to WR or RD   | t <sub>AVWL</sub>  | 66              | -    | 4t <sub>CLCL</sub> -55                               | -                      | ns   |  |
| WR or RD high to ALE high   | t <sub>WHLH</sub>  | 10              | 40   | t <sub>CLCL</sub> -20                                | t <sub>CLCL</sub> +20  | ns   |  |
| Data valid to WR transition | t <sub>QVWX</sub>  | 5               | -    | t <sub>CLCL</sub> -25                                | -                      | ns   |  |
| Data setup before WR        | t <sub>QVWH</sub>  | 142             | -    | 7t <sub>CLCL</sub> -70                               | -                      | ns   |  |
| Data hold after WR          | t <sub>WHQX</sub>  | 10              | -    | t <sub>CLCL</sub> -20                                | -                      | ns   |  |
| Address float after RD      | t <sub>RLAZ</sub>  | -               | 0    | -                                                    | 0                      | ns   |  |

## **Advance Information (40MHz)**

## **External Clock Drive**

| Parameter         | Symbol            | Variable<br>(Freq. = 3. | Unit          |    |
|-------------------|-------------------|-------------------------|---------------|----|
|                   |                   | Min.                    | Max.          |    |
| Oscillator period | tclcl             | 30.3                    | 285.7         | ns |
| High time         | t <sub>CHCX</sub> | 11.5                    | tclcl - tclcx | ns |
| Low time          | t <sub>CLCX</sub> | 11.5                    | tclcl - tchcx | ns |
| Rise time         | tclch             | -                       | 5             | ns |
| Fall time         | t <sub>CHCL</sub> | -                       | 5             | ns |





Figure 6. External Program Memory Read Cycle





Figure 7. External Data Memory Read Cycle



Figure 8. External Data Memory Write Cycle





AC Inputs during testing are driven at  $V_{CC}$ –0.5V for a logic '1' and 0.45V for a logic '0'. Timing measurements are made a  $V_{IHmin}$  for a logic '1' and  $V_{ILmax}$  for a logic '0'.

Figure 9. AC Testing: Input, Output Waveforms



For timing purposes a port pin is no longer floating when a 100mV change from load voltage occurs and begins to float when a 100mV change from the loaded  $V_{OH}$  /  $V_{OL}$  level occurs.  $I_{OL}$  /  $I_{OH} \ge 20$ mA.

Figure 10. Float Waveforms



Figure 11. External Clock Cycle



## **OSCILLATOR CIRCUIT**



Figure 12. Recommended Oscillator Circuits

Oscillation circuit is designed to be used either with a ceramic resonator or crystal oscillator. Since each crystal and ceramic resonator have their own characteristics, the user should consult the crystal manufacturer for appropriate values of external components.



## Plastic Package P-LCC-44

(Plastic Leaded Chip-Carrier)





## Plastic Package P-DIP-40

(Plastic Dual in-Line Package)





## Plastic Package P-MPQF-44

(Plastic Metric Quad Flat Package)





### **FLASH MEMORY**

#### Overview

The Flash memory increases EPROM and ROM functionality with in-circuit electrical erasure and programming. It contains 4K, 8K, 16K, 24K or 32K bytes of program memory. This memory is both parallel and serial In-System Programmable (ISP). ISP allows devices to alter their own program memory in the actual end product under software control. A default serial loader (bootloader) program allows ISP of the Flash. The programming does not require 12V external programming voltage. The necessary high programming voltage is generated on-chip using the standard  $V_{\rm CC}$  pins of the microcontroller.

#### **Features**

- · Flash memory internal program memory.
- Default loader in Boot ROM allows programming via the serial port without the need of a user provided loader.
- Up to 64K byte external program memory if the internal program memory is disabled (EA = 0).
- Programming and erase voltage with standard 5V V<sub>CC</sub> supply.
- Read/Programming/Erase:
  - Programming time per byte: 20us (TBD)
  - Block erase/Total Erase time: 200ms (TBD)
  - Typical programming time (32K bytes) is 10s at ISP mode (TBD)
- · Parallel programming with Atmel/Philips chip compatible hardware interface to programmer
- · Programmable security for the code in the Flash
- Endurance : 10,000 cycles (TBD)Data retention : 10 years (TBD)

Flash Programming and Erasure

There are three methods of programming the Flash memory:

- First, the on-chip ISP bootloader may be invoked which will use low level routines to program. The interface used for serial downloading of Flash memory is the UART.
- Second, the Flash may be programmed or erased in the end-user application by calling low level routines through a common entry point in the Boot ROM.
- Third, the Flash may be programmed using the parallel method by using conventional EPROM programmer. The commercially available programmers need to have support for the HMS99C51S/ 52S/54S/56S/58S. The bootloader routines are located in the Boot ROM.



## **Flash Memory Architecture**

HMS99C51S/52S/54S/56S/58S feature two on-chip Flash memories:

· Flash memory FM0:

4K/8K/16K/24K/32K bytes user program memory

• Flash memory FM1:

2K bytes for bootloader.

# The FM0 and FM1 can be programmed by both parallel programming and Serial In-System Programming.

The ISP mode is detailed in the "In-System Programming" section.

| 807F <sub>H</sub> | HSB (1byte)                  |
|-------------------|------------------------------|
|                   | Reserved                     |
| 7FFF <sub>H</sub> |                              |
|                   |                              |
|                   |                              |
|                   |                              |
|                   | 4K/8K/16K/24K/32K            |
|                   | Bytes User Application (FM0) |
|                   | ,                            |
|                   |                              |
| $0000_{\rm H}$    |                              |



FM1(2K bytes): Boot Loader

## **FM0 Memory Architecture**

- 4K/8K/16K/24K/32K bytes User Program Memory
- · Hardware Security Bits (HSB)

#### **User Space**

This space is composed of a 4K/8K/16K/24K/32K bytes Flash memory. HMS99C51S/52S has only sectors of 2K byte unit block, and HMS99C54S/56S/58S has 4 sectors of 2K byte unit block and other sectors of 8K byte unit block. It contains the user's application code.

#### **Hardware Security Byte**

The Hardware Security Byte space is a part of HSB and has a size of 1 byte.



#### **Cross Flash Memory Access Description**

The FM0 and FM1 memory can be programmed by parallel programming.

The FM0 memory can be programmed from FM1. But, programming FM1 from FM0 or from external memory is impossible.

FM1 memory can be programmed only by parallel programming.

| _                   |     | Action      | FM0<br>(User Flash) | FM1<br>(Boot Flash) |
|---------------------|-----|-------------|---------------------|---------------------|
| Code Executing from | EMO | Read        | ок                  | -                   |
|                     | FM0 | Write/Erase | -                   | -                   |
|                     | FM1 | Read        | ок                  | ок                  |
|                     |     | Write/Erase | ОК                  | -                   |

**Table 11. Cross Flash Memory Access** 

#### **Overview of FM0 Operations**

The CPU interfaces to the Flash memory through the FCON register of SFR FCON register is used to:

- · Select Register for operation of Flash Access (FRSEL[2:0])
- Erase Mode Select (ERASESEL)
- Enable Boot Flash (ENBOOT)
- 64K Bytes Internal Rom Access (INTROM\_EN)
- Program Mode Select (PGMSEL)

#### **Mapping of the Memory Space**

By default, the user space is accessed by MOVC instruction for read only.

The other memory spaces (user, BOOT, HSB) are made accessible in the code segment by programming bits INTROM\_EN, ENBOOT in FCON register in advance. A MOVC instruction is then used for reading these spaces in accordance with address of Table 12.

| Region          | Addr. 15 | Addr. 14~11 | Addr. 10~7 | Addr. 6~0 |
|-----------------|----------|-------------|------------|-----------|
| HSB(1 Bytes)    | 4        | 0000        | 0111       | 1111      |
| Boot(2K Bytes)  |          | 1111        | Variable   | Variable  |
| User(32K Bytes) | 0        | Variable    | Variable   | Variable  |

Table 12. FM0 Blocks Select Bits



## Flash Registers and Memory Map

The HMS99C51S/52S/54S/56S/58S Flash memory uses several registers for its management:

• Hardware registers can only be accessed through the parallel programming modes which are handled by the parallel programmer.

## **Hardware Register**

The only hardware register of the HMS99C51S/52S/54S/56S/58S is called Hardware Security Byte(HSB).



Table 13. Hardware Security Byte(HSB)

| Bit No | Bit Mnemonic | Description                                                                                                                                                        |
|--------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7~5    | -            | Reserved                                                                                                                                                           |
| 4      | BLJN_EN      | Enable BLJB Bit 1 : BLJB is enabled for ISP Mode 0 : BLJB is disabled. (After finishing of download, must be programmed.)                                          |
| 3      | BLJB         | Boot Loader Jump Bit 1 : Start the user's application on next reset at address 0000 <sub>H</sub> 0 : Start the boot loader at address F800 <sub>H</sub> (Default). |
| 2~0    | LB2~0        | User Memory Lock Bits<br>See Table 14                                                                                                                              |

1 : Unprogrammed 0 : Programmed

**Note:** HSB can be read but can not be programmed in ISP Mode and only programmable by specific tools.



#### Flash Memory Lock Bits

The three lock bits provide different levels of protection for the on-chip code and data, when programmed as shown in Table 14.

|                   | Program Lock Bit |     |     |                                                                                                                                                                                                                                                                           |
|-------------------|------------------|-----|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Security<br>Level | LB0              | LB1 | LB2 | Protection Description                                                                                                                                                                                                                                                    |
| 1                 | U                | U   | U   | No program lock features enabled.                                                                                                                                                                                                                                         |
| 2                 | Р                | U   | U   | MOVC instruction executed from external program memory is disabled from fetching code bytes from internal memory, EA is sampled and latched on reset, and further parallel programming of the Flash is disabled. ISP and software programming with ISP are still allowed. |
| 3                 | Х                | Р   | U   | Same as 2, also verify through parallel programming interface is disabled.                                                                                                                                                                                                |
| 4                 | Х                | Х   | Р   | Same as 3, also external execution is disable.                                                                                                                                                                                                                            |

**Table 14. Program Lock Bits** 

Note: U: unprogrammed or "1", P: programmed or "0", X: don't care

Note: Security level 2 and 3 should only be programmed after Flash and code verification.

These security bits protect the code access through the parallel programming interface. They are set by default to level 1. Though at level 2, 3 and 4, the code access through the ISP is still possible.

#### **Default Values**

The default value of the HSB provides parts ready to be programmed with ISP

- BLJB EN: BLJB bit is enabled or disabled.(default : disabled)
- BLJB: Programmed force ISP operation(Default : ISP inactivated)).
- LB2-0: Security level four to protect the code from a parallel access with maximum security.(Default : Level 1)

#### **Software Security**

The software security provide two different levels of protection for the on-chip code and data,

- Level 1: No program lock features enabled.
- Level 2: ISP programming and verify of the Flash is disabled.



## Flash Memory Status

HMS99C51S/52S/54S/56S/58S themselves are delivered in standard with the ISP boot code in the Flash memory. After ISP or parallel programming, the possible contents of the Flash memory are summarized on Figure 13.



Figure 13. Flash Memory Possible Contents

## **Memory Organization**

In the HMS99C51S/52S/54S/56S/58S, the lowest 4K, 8K, 16K, 24K or 32K of the 64 KB program memory address space is filled by internal Flash cells. When the  $\overline{EA}$  pin is high, the processor fetches instructions from internal program Flash memory. Bus expansion for accessing program memory from 4K, 8K, 16K, 24K or 32K is upward since external instruction fetches occur automatically when the program counter exceeds 0FFFh(4K), 1FFFh(8K), 3FFFh(16K), 5FFFh(24K) or 7FFFh (32K).

If the  $\overline{EA}$  pin is tied low, all program memory fetches are from external memory.



## Flash Management Block

· Flash Management Block is controlled by ISP Command

.

## FLASH DIGITAL BLOCK





## SFR Register for a ISP Mode

FCON register exists in  $D1_H$  in SFR region and defines selection of Flash register operation, R/W for a Flash Registers, BOOT Flash usage, selection of Flash Memory Space and selection of Program location.

| D0 <sub>H</sub> | PCON<br>00000000 <sub>B</sub> | FCON<br>00000000B | - | - | - | - | D7 <sub>H</sub> |  |
|-----------------|-------------------------------|-------------------|---|---|---|---|-----------------|--|
|-----------------|-------------------------------|-------------------|---|---|---|---|-----------------|--|

Table 15. SFR Register for a Flash memory

## FCON (Flash Control) Register: D1<sub>H</sub>

| Bit 7  | Bit 6  | Bit 5  | Bit 4    | Bit 3  | Bit 2     | Bit 1   | Bit 0   |
|--------|--------|--------|----------|--------|-----------|---------|---------|
| FRSEL2 | FRSEL1 | FRSEL0 | ERASESEL | ENBOOT | INTROM_EN | PGMSEL1 | PGMSEL0 |

| Bit No | Bit Mnemonic | Description                                                                                                            |
|--------|--------------|------------------------------------------------------------------------------------------------------------------------|
| 7~5    | FRSEL[2:0]   | Select Register Operation for Flash Access This bits define register operation for Flash Memory Access See Figure 16.  |
| 4      | ERASESEL     | ERASESEL 0 : Erase Mode is deselected 1 : Erase Mode is selected                                                       |
| 3      | ENBOOT       | Enable Boot Flash Cleared to disable boot ROM Set to map the boot ROM between F800 <sub>H</sub> ~ 0FFFF <sub>H</sub> . |
| 2      | INTROM_EN    | Internal ROM Access Enable bit 0 : External Memory Access over 32K bytes 1 : Internal Memory Access to use Boot ROM    |
| 1~0    | PGMSEL[1:0]  | The Program Location Select 00 : Reserved 01 : 1 Byte Program 10 : 4 Byte Program 11 : 8 Byte Program                  |

| FRSEL[2:0]                       | Operation              |                                                      |
|----------------------------------|------------------------|------------------------------------------------------|
| 0 (000 <sub>B</sub> )<br>Default | Verify / Read          | Reset CONTREG [7:0]<br>DATA_BUS [7:0] → ACC[7:0]     |
| 4 (100 <sub>B</sub> )            | Write Address and Data | DPTR[14:0] → ADDREG[14:0]<br>ACC[7:0] → DATAREG[7:0] |
| 5 (101 <sub>B</sub> )            | Write CONTREG          | ACC[7:0] → CONTREG[7:0]                              |
| 6 (110 <sub>B</sub> )            | Write EBR              | ACC[7:0] → EBR[6:0]                                  |
| 7 (111 <sub>B</sub> )            | Write PWR              | ACC[7:0] → PWR[7:0]                                  |

Table 16. Register Operation Table for Flash Access



| Bit Position | Name    | Function            |                                   |
|--------------|---------|---------------------|-----------------------------------|
| Bit0         | PGM_SET | Program Power Setup | Positive Gate Pump Setup          |
| Bit1         | ER_SET  | Erase Power Setup   | Negative/Positive Gate Pump Setup |
| Bit2~Bit7    | -       | -                   | Reserved                          |

Table 17. Control Register

| Bit Position | Name         | Function                                         | Function Effect                                                                                        |
|--------------|--------------|--------------------------------------------------|--------------------------------------------------------------------------------------------------------|
| Bit7 ~ Bit6  | VEEIOPT[1:0] | Define VEEI<br>(Negative Pump Output Value)      | 00 : VEEI → -09V<br>01 : VEEI → -10V<br>10 : VEEI → -11V                                               |
| Bit5 ~ Bit4  | VPPIOPT[1:0] | Define VPPI<br>(Positive Gate Pump Output Value) | 00 : VPPI → 09V<br>01 : VPPI → 10V<br>10 : VPPI → 11V                                                  |
| Bit3         | DNWOPT       | Define DNWELL Bias                               | 0 : DNWELL Bias = V <sub>CC</sub> -V <sub>T</sub><br>1 : DNWELL Bias = V <sub>PP</sub> -V <sub>T</sub> |
| Bit2         | I_ER_VFY     | ER_VFY                                           | 1: Down the level to check a erased cell (around 1V) 0: default(around 2V)                             |
| Bit1         | I_PGM_VFY    | PGM_VFY                                          | 1: Up the level to check a pro-<br>grammed cell (around 6V)<br>0: default(around 5V)                   |
| Bit0         | -            | Reserved                                         | For Other Test                                                                                         |

Table 18. Power Register

| Bit Position | Name | Function                                            | Function Effect |
|--------------|------|-----------------------------------------------------|-----------------|
| Bit0         | EBR0 | Erase Block (0000 <sub>H</sub> ~07FF <sub>H</sub> ) | Erase 2K Bytes  |
| Bit1         | EBR1 | Erase Block (0800 <sub>H</sub> ~0FFF <sub>H</sub> ) | Erase 2K Bytes  |
| Bit2         | EBR2 | Erase Block (1000 <sub>H</sub> ~17FF <sub>H</sub> ) | Erase 2K Bytes  |
| Bit3         | EBR3 | Erase Block (1800 <sub>H</sub> ~1FFF <sub>H</sub> ) | Erase 2K Bytes  |
| Bit4         | EBR4 | Erase Block (2000 <sub>H</sub> ~3FFF <sub>H</sub> ) | Erase 8K Bytes  |
| Bit5         | EBR5 | Erase Block (4000 <sub>H</sub> ~5FFF <sub>H</sub> ) | Erase 8K Bytes  |
| Bit6         | EBR6 | Erase Block (6000 <sub>H</sub> ~7FFF <sub>H</sub> ) | Erase 8K Bytes  |

Table 19. Erase Block Register(EBR)



### **Bootloader Architecture**

#### Introduction

The bootloader manages a communication according to a specific defined protocol to provide the whole access and service on Flash memory. Furthermore, all accesses and routines can be called from the user application

The Flash bootloader includes:

- The serial communication protocol
- The ISP command decoder
   In order to access User FLASH area at a custom bootloader, User must modify the related FLASH registers directly.

This may be necessary in case of:

- · Another communication interface
- Different protocol (other data format, encrypted data, etc.)
- · Flash areas protection
- Flash areas checks (CRC, etc.)



Figure 14. Diagram Context Description



#### **Bootloader Functional Description**



Figure 15. Bootloader Functional Description

On the above diagram, the on-chip bootloader processes are:

#### • ISP Communication Management

The purpose of this process is to manage the communication and its protocol between the on-chip bootloader and a external device. The on-chip boot ROM implement a serial protocol. This process translate serial communication frame (UART) into Flash memory access (read, write, erase, ...)

#### · Flash Memory Management

This process manages low level access to Flash memory (performs read, write and erase access).



#### **Bootloader Process**

The bootloader can be activated by Hardware conditions. The Hardware conditions ( $\overline{PSEN} = 0$ ,  $\overline{EA} = 1$ , ALE = 1) during the Reset falling edge force the on-chip bootloader execution. This allows an application to be built that will normally execute the end user's code but can be manually forced into default ISP operation. As  $\overline{PSEN}$  is a an output port in normal operating mode (running user application or bootloader code) after reset, it is recommended to release  $\overline{PSEN}$  after falling edge of reset signal. The hardware conditions are sampled at reset signal falling edge, thus they can be released at any time when reset input is low. The on-chip bootloader boot process is shown in Figure 16.



Figure 16. Bootloader Process by hardware

•



## **IN-SYSTEM PROGRAMMING (ISP)**

The In-System Programming (ISP) is performed without removing the microcontroller from the system. The ISP facility consists of a series of internal hardware resources coupled with internal firmware to facilitate remote programming of the HMS99C51S/52S/54S/56S/58S through the serial port. The MagnaChip Microcontrollers ISP facility has made in-circuit programming in an embedded application possible with a minimum of additional expense in components and circuit board area. The ISP function through UART uses four pins: TxD, RxD, Vss, and Vcc. Only a small connector needs to be available to interface the application to an external circuit in order to use this feature.

## **Using In-System Programming (ISP)**

The ISP feature allows a wide range of baud rates in the user application. It is also adaptable to a wide range of oscillator frequencies. This is accomplished by measuring the bit-time of a single bit in a received character. This information is then used to program the baud rate in terms of timer counts based on the oscillator frequency.

The ISP feature requires that an initial character(an uppercase U) be sent to the HMS99C51S/52S/54S/56S/58S to establish the baud rate. The ISP firmware provides auto-echo of received characters. Once baud rate initialization has been performed, the ISP firmware will only accept Intel Hex-type records. Intel Hex records consist of ASCII characters used to represent hexadecimal values and are summarized below:

#### :NNAAAARRDD...DDCC

HMS99C51S/52S/54S/56S/58S will accept up to 16(10<sub>H</sub>) data bytes. The "AAAA" string represents the address of the first byte in the record. If there are zero bytes in the record, this field is often set to "0000". The "RR" string indicates the record type. A record type of "00" is a data record. A record type of "01" indicates the end-of-file mark. In this application, additional record types will be added to indicate either commands or data for the ISP facility. The "DD" string represents the data bytes. The maximum number of data bytes in a record is limited to 16(decimal). The "CC" string represents the checksum byte. ISP commands are summarized in Table 22. As a record is received by the HMS99C51S/52S/54S/56S/58S, the information in the record is stored internally and a checksum calculation is performed and compared to "CC". The operation indicated by the record type is not performed until the entire record has been received. Should an error occur in the checksum, the HMS99C51S/52S/54S/56S/58S will send an "X" out the serial port indicating a checksum error. If the checksum calculation is found to match the checksum in the record, then the command will be executed. In most cases, successful reception of the record will be indicated by transmitting a "." character out the serial port(displaying the contents of the internal program memory is an exception). In the case of a Data Record(record type "00"), an additional check is made. A "." character will NOT be sent unless the record checksum matched the calculated checksum and all of the bytes in the record were successfully programmed.

For a data record, an "X" indicates that the checksum failed to match, and an "R" character indicates that one of the bytes did not properly program.

MagnaChip ISP, a software utility to implement ISP programming with a PC, is available from the MagnaChip web site. The users of this ISP function should use this MagnaChip ISP software for proper flash ROM control and operation.



| RECORD TYPE | COMMAND/DATA FUNCTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 00          | Program Data Record :nnaaaa00dd ddcc Where: nn = number of bytes(hex) in record aaaa = memory address of first byte in record dddd=databytes cc = checksum Example: :05008000AF5F67F060B6                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 01          | End of File (EOF), no operation :xxxxxx01cc Where: xxxxxx = required field, but value is a "don't care" cc = checksum Example: :00000001FF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 02          | Specify Erase/Write Pulse :03xxxx02wweellcc Where: xxxx = required field, but value is a "don't care" ww = write pulse ee = erase pulse high byte II = erase pulse low byte cc = checksum Example: :03000002789C40A7                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 03          | Miscellaneous Write Functions :nnxxxx03ffssddcc Where: nn = number of bytes(hex) in record xxxx = required field, but value is a "don't care" 03 = Write Function ff = subfunction code ss = selection code dd = data input(as needed) cc = checksum Subfunction Code = 01(Erase Block) ff = 01 ss = block index in bits 6:0 (block number is designated by bit position) Example: :020000030122D8 erase block 1 and 5 (position of bit 1 and 5) Subfunction Code = 05 (Program Software Security Bits) ff = 05 program software security bit (Level 2 inhibit reading/writing to Flash) Example: :0100000305F7 (program security bit) |

Table 20. Intel-Hex Records Used by In-system Programming



| RECORD TYPE | COMMAND/DATA FUNCTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 04          | Display Device Data or Blank Check Record type 04 causes the contents of the entire Flash array to be sent out the serial port in a formatted display. This display consists of an address and the contents of 16 bytes starting with that address. No display of the device contents will occur if security bit 2 has been programmed. The dumping of the device data to the serial port is terminated by the reception of any character.  General Format of Function 04:05xxxx04sssseeeeffcc  Where:  05 = number of bytes (hex) in record  xxxx = required field, but value is a "don't care"  04 = "Display Device Data or Blank Check" function code  ssss = starting address eeee = ending address ff = subfunction 00 = display data 01 = blank check cc = checksum  Example: :0500000440004FFF0069 (display 4000H ~ 4FFFH) |
| 05          | Miscellaneous Read Functions General Format of Function 05 :02xxxx05ffsscc Where: 02 = number of bytes (hex) in record xxxx = required field, but value is a "don't care" 05= "Miscellaneous Read" function code ffss = subfunction and selection code 0001 = read copy of the signature byte - device ID (Family code) 0700 = read the software security bits 0703 = read the oscillation information cc = checksum Example: :020000050001F0 (read copy of the signature byte - device id)                                                                                                                                                                                                                                                                                                                                        |

Table 20. Intel-Hex Records Used by In-system Programming



| Command                        | Command Name      | Data[0]                                                                                             | Data[1]         | Command Effect                                                                                                                                                                                                                                                                                                                                                                                                           |
|--------------------------------|-------------------|-----------------------------------------------------------------------------------------------------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 00 <sub>H</sub>                | Program Data      | -                                                                                                   | -               | Program Data Byte Bootloader will accept up to 128 data bytes.                                                                                                                                                                                                                                                                                                                                                           |
| 01 <sub>H</sub>                | End Of File       | -                                                                                                   | -               | End Of File                                                                                                                                                                                                                                                                                                                                                                                                              |
| 02 <sub>H</sub>                | Specify E/W Pulse | Data[0] = write<br>Data[1] = eras<br>Data[2] = eras                                                 | se times high   | Erase/Write pulse information setup                                                                                                                                                                                                                                                                                                                                                                                      |
| 03 <sub>H</sub> Write function | Write function    | 01H                                                                                                 | Block<br>index  | Bit 0 : Erase Blk0(0000 $_{H}$ ~07FF $_{H}$ ); 2K bytes Bit 1 : Erase Blk1(0800 $_{H}$ ~0FFF $_{H}$ ); 2K bytes Bit 2 : Erase Blk2(1000 $_{H}$ ~17FF $_{H}$ ); 2K bytes Bit 3 : Erase Blk3(1800 $_{H}$ ~1FFF $_{H}$ ); 2K bytes Bit 4 : Erase Blk4(2000 $_{H}$ ~3FFF $_{H}$ ); 8K bytes Bit 5 : Erase Blk5(4000 $_{H}$ ~7FFF $_{H}$ ); 8K bytes Bit 6 : Erase Blk0(6000 $_{H}$ ~7FFF $_{H}$ ); 8K bytes Bit 7 : not used |
|                                |                   | 05H                                                                                                 | -               | Program Security Lockbit                                                                                                                                                                                                                                                                                                                                                                                                 |
|                                |                   | 07H                                                                                                 | -               | Erase User Memory fully(max. 32K bytes)                                                                                                                                                                                                                                                                                                                                                                                  |
| 04 <sub>H</sub>                | Display function  | Data[0:1] = start address Data[2:3] = end address Data[4] = 00h(Display) Data[4] = 01h(Blank check) |                 | Display Data/Blank Check                                                                                                                                                                                                                                                                                                                                                                                                 |
|                                |                   | 00 <sub>H</sub>                                                                                     | 01 <sub>H</sub> | Read Device id                                                                                                                                                                                                                                                                                                                                                                                                           |
| 05 <sub>H</sub>                | Read Function*    | 07 <sub>H</sub>                                                                                     | 00 <sub>H</sub> | Read Security Information                                                                                                                                                                                                                                                                                                                                                                                                |
|                                |                   |                                                                                                     | 03н             | Read Oscillator Information                                                                                                                                                                                                                                                                                                                                                                                              |

**Table 21. ISP Commands Summary** 



#### **Serial Protocol**

This application note describes the Serial Protocol used to program the Flash code memory from MagnaChip microcontrollers. Commands sent over the serial line are interpreted by the on-chip bootloader program.

This applied for HMS99C51S/52S/54S/56S/58S.

This protocol is a serial UART protocol.



## **Protocol Configuration**

## 1. Physical Layer

The UART used to transmit information has the following configuration:

· Character: 8-bit data

Parity: noneStop: 1 bit

· Flow control: none

• Baudrate: autobaud is performed by the bootloader to compute the baudrate chosen by the host.

### 2. Frame Description

The Serial Protocol is based on the Intel Hex-type records.

Intel Hex records consist of ASCII characters used to represent hexadecimal values and are summarized below:

| Record Mark | Reclen | Load Offset | Record Type | Data or Info | Checksum |
|-------------|--------|-------------|-------------|--------------|----------|
| 1 Byte      | 1 Byte | 2 Byte      | 1 Byte      | n Byte       | 1 Byte   |



#### · Record Mark:

Record Mark is the start of frame. This field must contain ':'.

#### · Reclen:

Reclen specifies the number of bytes of information or data which follows the Record Type field of the record.

#### Load Offset

Load Offset specifies the 16-bit starting load offset of the data bytes, therefore this field is used only for Data Program Record(see Table 20).

#### · Record Type:

Record Type specifies the command type. This field is used to interpret the remaining information within the frame. The encoding for all the current record types is described in Table 20.

#### · Data/Info:

Data/Info is a variable length field. It consists of zero or more bytes encoded as pairs of hexadecimal digits. The meaning of data depends on the Record Type.

#### · Checksum:

The two's complement of bytes that result from converting each pair of ASCII hexadecimal digits to one byte of binary, and including the Reclen field to and including the last byte of the Data/Info field. Therefore, the sum of all the ASCII pairs in a record after converting to binary, from the Reclen field to and including the Checksum field, is zero.

#### Note: 1. A data byte is represented by two ASCII characters

2. When the field Load Offset is not used, it should be coded as four ASCII zero characters ('0').



## **Protocol Description**

#### 1.Overview

An initialization step must be performed after each Reset. After microcontroller reset, the bootloader waits for an autobaud sequence. When the communication is initialized, the protocol depends on the record type requested by the host.

#### 2.Communication Initialization

The host initializes the communication by sending a "U" character to help the bootloader to compute the baudrate (autobaud).



#### 3.Command Data Stream Protocol

All commands are sent using the same flow.



Note: All commands sent with the echo mechanism will be represented by:



#### 3.1 Write / Program Commands

This flow is common to the following frames:

- · Flash Programming Data Frame
- EOF or MagnaChip Frame (only Programming MagnaChip Frame)
- · Erase/Write Timing Frame
- · Lockbit Programming Data Frame

#### a. Description



Erase/Write Flow

## b. Example

HOST: 01 0010 00 55 9A

BOOTLOADER: 01 0010 00 55 9A. CR LF

Programming Data (write 55<sub>H</sub> at address 0010<sub>H</sub> in the Flash)

HOST: 02 0000 03 05 01 F5

BOOTLOADER: 02 0000 03 05 01 F5. CR LF

Programming Lockbit function (write Software Security to level 2)



#### 3.2 Blank Check Command

#### a. Description



Blank Check Flow

#### b. Example

HOST: 05 0000 04 0000 7FFF 01 78

BOOTLOADER: 05 0000 04 0000 7FFF 01 78. CR LF

Blank Check ok

BOOTLOADER: 05 0000 04 0000 7FFF 01 70 X CR LF CR LF

Blank Check with checksum error HOST: 05 0000 04 0000 7FFF 01 70

BOOTLOADER: 05 0000 04 0000 7FFF 01 78 xxxx CR LF

Blank Check failure at address xxxx



#### 3.3 Display Data

#### a. Description



 ${\it Note: The maximum size of display block is equal to the Flash ROM size.}$ 

## b. Example

HOST: 05 0000 04 0000 0020 00 D7

BOOTLOADER: 05 0000 04 0000 0020 00 D7

BOOTLOADER 0000=----data----- / CR LF (16 data)

BOOTLOADER 0010=-----data------ / CR LF (16 data)

BOOTLOADER 0020=data CR LF ( 1 data) Display data from address  $0000_{\rm H}$  to  $0020_{\rm H}$ 



#### 3.4. Read Function

This flow is similar for the following frames:

- · Reading Frame
- EOF Frame/ MagnaChip Frame (only reading MagnaChip Frame)

### a. Description



Read Flow

## b. Example

HOST: 02 0000 05 00 01 F8

BOOTLOADER: 02 0000 05 00 01 F8 Value. CR LF

Read function (read device ID)



## ISP METHOD FOR PC(MAGNACHIP WINISP)

## **Getting Started / Installation**

The following section details the procedure for accomplishing the installation procedure.

- 1. Connect the serial(RS-232C) cable between a target board and the COM1 serial port of your PC.
- 2. Configure the COM1 serial port of your PC as following.

• Baudrate: 115,200

Data bit: 8Parity: NoStop bit: 1Flow control: No

- 3. Turn your target B/D power switch ON.
  Your target B/D must be configured to enter the ISP mode.
- 4. Run the MagnaChip ISP software.
- 5. Press the Reset Button in the ISP S/W.

If the status windows shows a message as "Connected", all the conditions for ISP are provided.

If you press the Reset button again after connected, the status windows will show the message as "Disconnected". Please discard it because the HMS99C51S/52S/54S/56S/58S can not check the reset button after connected successfully.



#### **Basic Information**



| Function      | Description                                                                                                                     |
|---------------|---------------------------------------------------------------------------------------------------------------------------------|
| Load HEX File | Load the data from the selected file storage into the memory buffer.                                                            |
| Save HEX File | Save the current data in your memory buffer to a disk storage by using the Intel HEX format.                                    |
| Erase         | Erase the data in your target MCU before programming it.                                                                        |
| Blank Check   | Verify whether or not a device is in an erased or unprogrammed state.                                                           |
| Program       | This button enables you to place new data from the memory buffer into the target device.                                        |
| Read          | Read the data in the target MCU into the buffer for examination. The checksum will be displayed on the checksum box.            |
| Verify        | Assures that data in the device matches data in the memory buffer. If your device is secured, a verification error is detected. |
| Lock          | Secures devices so that their content can no longer be examined or modified.                                                    |

**Table 22. ISP Function Description** 



| Function      | Description                                                                                                                                                                                                                                                                                                                              |
|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Erase Option  | Select blocks for Erasure.                                                                                                                                                                                                                                                                                                               |
| AUTO          | Blank Check & Program & Verify                                                                                                                                                                                                                                                                                                           |
| Auto Lock     | If selected with check mark, the security locking is performed after erasure.                                                                                                                                                                                                                                                            |
| Connect       | Connect a MCU in your target Board with displaying as "Connected" in the status box. Users have to press this button at least one time to initialize a target MCU for entering the ISP mode. If failed to enter the ISP mode, all the buttons are unavailable. And, after entering successfully, the Connect button will be unavailable. |
| Edit Buffer   | Modify the data in the selected address in your buffer memory                                                                                                                                                                                                                                                                            |
| Fill Buffer   | Fill the selected area with a data.                                                                                                                                                                                                                                                                                                      |
| Goto          | Display the selected page.                                                                                                                                                                                                                                                                                                               |
| OSC MHz       | Display your target system's oscillator value with discarding below point.                                                                                                                                                                                                                                                               |
| Start         | Starting address                                                                                                                                                                                                                                                                                                                         |
| End           | End address                                                                                                                                                                                                                                                                                                                              |
| Checksum=8000 | Display the checksum(Hexdecimal) after reading the target device.                                                                                                                                                                                                                                                                        |
| Com Port      | Select serial port.                                                                                                                                                                                                                                                                                                                      |
| Baud Rate     | Select UART baud rate.                                                                                                                                                                                                                                                                                                                   |
| Select Device | Select target device.                                                                                                                                                                                                                                                                                                                    |
| Page Up Key   | Display the previous page of your memory buffer.                                                                                                                                                                                                                                                                                         |
| Page Down Key | Display the higher page than the current location.                                                                                                                                                                                                                                                                                       |

**Table 22. ISP Function Description** 



#### **Hardware Conditions to Enter the ISP Mode**

The In-System Programming (ISP) is performed without removing the microcontroller from the system. The In-System Programming(ISP) facility consists of a series of internal hardware resources coupled with internal firmware through the serial port. The In-System Programming (ISP) facility make in-circuit programming in an embedded application possible with a minimum of additional expense in components and circuit board area.

The bootloader can be executed by holding  $\overline{PSEN}$  LOW,  $\overline{EA/V_{PP}}$  greater than  $V_{IH}$  (such as +5V), and ALE/ $\overline{PROG}$  HIGH at the falling edge of RESET. The ISP function block uses four pins: TxD, RxD, V<sub>SS</sub>, and V<sub>CC</sub>. Only a small connector needs to be available to interface your application to an external circuit in order to use this feature.

